当前位置:   article > 正文

利用腾讯云COS云对象存储定时远程备份网站_qcloud_cos

qcloud_cos

版权声明:本文由张戈  原创文章,转载请注明出处: 
文章原文链接:https://www.qcloud.com/community/article/942851001487125915

来源:腾云阁 https://www.qcloud.com/community

 

一、优点分析

内网传输:和阿里云OSS一样,腾讯云COS同样支持内网和外网文件传输,对于腾讯云服务器,使用内网传输绝对是最快、最稳定的备份方案!

免费方案:看了下腾讯云COS的定价说明,发现对于备份网站来说简直是绝佳搭档,甚至可以说是钻了个空子(希望腾讯云的同事看到别打我。。。)!为啥这么说?

看下定价方案:

①、入流量免费

相当于我们上传文件的流量都是免费的,不区分内外网哦!内网就不说了,都懂。

②、各种免费额度

以七天循环备份(7份压缩包)以来算,单压缩包支持700M+(700M*7≈50G),应付一般网站的备份绝对是足够足够足够了!

二、准备工作

①、开通COS,并创建Bucket

访问腾讯云COS开通对象存储服务,然后如图创建Bucket:

Ps:我们只用于备份,且为私密资料,所以选择私有读写。

②、添加密钥

接着,我们点击左侧的密钥管理,进入密钥界面如图创建密钥,如果先前已经有密钥了,则可以直接使用:

三、备份脚本

人生苦短,我用Python,这里就继续选择Python SDK来实现,

①、环境准备

如下顺序安装腾讯云Python SDK插件

  1. #安装pip
  2. yum install python-pip
  3. #升级pip(yum装的可能版本比较旧)
  4. pip install --upgrade pip
  5. #安装腾讯云COS SDK插件
  6. pip install qcloud_cos

如果不是Centos,请自行搞定,这里不再赘述。

②、上传脚本

参考官方SDK文档,写了一个简单够用的上传脚本:

  1. # -*- coding: utf-8 -*-
  2. # Upload File To Qcloud COS
  3. from qcloud_cos import CosClient
  4. from qcloud_cos import UploadFileRequest
  5. import sys
  6. #脚本需要传入6个参数
  7. if ( len(sys.argv) > 5 ):
  8. appid = int(sys.argv[1])
  9. secret_id = sys.argv[2].decode('utf-8')
  10. secret_key = sys.argv[3].decode('utf-8')
  11. bucket = sys.argv[4].decode('utf-8')
  12. domain = sys.argv[5].decode('utf-8')
  13. filePath = sys.argv[6].decode('utf-8')
  14. fileName = filePath.split("/")[-1]
  15. else:
  16. print("Example: python %s appid secret_id secret_key Bucket zhangge.net /data/backup.zip" % sys.argv[0])
  17. exit()
  18. #认证和上传
  19. cos_client = CosClient(appid, secret_id, secret_key)
  20. request = UploadFileRequest(bucket, '/%s/%s' % ( domain, fileName ), filePath)
  21. request.set_insert_only(0)
  22. upload_file_ret = cos_client.upload_file(request)
  23. print 'The File %s Upload to Bucket %s : %s ' % ( filePath , bucket , upload_file_ret.get('message') )

使用方法:将上述代码保存为 cos.upload.py,并上传到服务器,执行如下命令可开始上传文件到OSS:

python /data/oss.upload.py appid secret_id secret_key Bucket名称 域名 /data/zhangge.net_1.zip

其中:

  • 1~3个参数是appid、认证ID和认证密钥,也就是前文创建并备忘的密钥信息;
  • 第4个参数是前文创建的Bucket名称,比如mybackup
  • 第5个参数是需要备份的域名(新增的:主要是为了区分下)
  • 第6个参数是要上传的本地文件的绝对路径

执行后,就能在COS的Object界面看到了上传的文件:

四、定时备份

有了上传脚本,继续结合之前张戈博客分享的七天循环备份脚本,实现循环备份到COS了,既安全还节省COS空间。

①、适合COS七天循环备份脚本
  1. #!/bin/sh
  2. ###################################################################
  3. # Web Backup version 1.0.0 Author: Jager <ge@zhangge.net> #
  4. # For more information please visit https://zhangge.net/5117.html #
  5. #-----------------------------------------------------------------#
  6. # Copyright ©2016 zhangge.net. All rights reserved. #
  7. ###################################################################
  8. isDel=n
  9. args=$#
  10. isDel=${!args}
  11. mypassword=123456
  12. test -f /etc/profile && . /etc/profile >/dev/null 2>&1
  13. baseDir=$(cd $(dirname $0) && pwd)
  14. zip --version >/dev/null || yum install -y zip
  15. ZIP=$(which zip)
  16. TODAY=`date +%u`
  17. PYTHON=$(which python)
  18. MYSQLDUMP=$(which mysqldump)
  19. # 新增的COS上传文件函数,请按照实际情况修改appID,认证KEY、认证密钥和Bucket名称!!!
  20. uploadToCOS()
  21. {
  22. $PYTHON $baseDir/cos.upload.py appID 认证KEY 认证密钥 Bucket名称 $1 $2
  23. if [[ $? -eq 0 ]] && [[ "$isDel" == "y" ]]
  24. then
  25. test -f $2 && rm -f $2
  26. fi
  27. }
  28. printHelp()
  29. {
  30. clear
  31. printf '
  32. =====================================Help infomation=========================================
  33. 1. Use For Backup database:
  34. The $1 must be [db]
  35. $2: [domain]
  36. $3: [dbname]
  37. $4: [mysqluser]
  38. $5: [mysqlpassword]
  39. $6: [back_path]
  40. $7: [isDel]
  41. For example:./backup.sh db zhangge.net zhangge_db zhangge 123456 /home/wwwbackup/zhangge.net
  42. 2. Use For Backup webfile:
  43. The $1 must be [\file]:
  44. $2: [domain]
  45. $3: [site_path]
  46. $4: [back_path]
  47. $5: [isDel]
  48. For example:./backup.sh file zhangge.net /home/wwwroot/zhangge.net /home/wwwbackup/zhangge.net
  49. =====================================End of Hlep==============================================
  50. '
  51. exit 0
  52. }
  53. backupDB()
  54. {
  55. domain=$1
  56. dbname=$2
  57. mysqluser=$3
  58. mysqlpd=$4
  59. back_path=$5
  60. test -d $back_path || (mkdir -p $back_path || echo "$back_path not found! Please CheckOut Or feedback to zhangge.net..." && exit 2)
  61. cd $back_path
  62. #如果是要备份远程MySQL,则修改如下语句中localhost为远程MySQL地址
  63. $MYSQLDUMP -hlocahost -u$mysqluser -p$mysqlpd $dbname --skip-lock-tables --default-character-set=utf8 >$back_path/$domain\_db_$TODAY\.sql
  64. test -f $back_path/$domain\_db_$TODAY\.sql || (echo "MysqlDump failed! Please CheckOut Or feedback to zhangge.net..." && exit 2)
  65. $ZIP -P$mypassword -m $back_path/$domain\_db_$TODAY\.zip $domain\_db_$TODAY\.sql && \
  66. uploadToCOS $domain $back_path/$domain\_db_$TODAY\.zip
  67. }
  68. backupFile()
  69. {
  70. domain=$1
  71. site_path=$2
  72. back_path=$3
  73. test -d $site_path || (echo "$site_path not found! Please CheckOut Or feedback to zhangge.net..." && exit 2)
  74. test -d $back_path || (mkdir -p $back_path || echo "$back_path not found! Please CheckOut Or feedback to zhangge.net..." && exit 2)
  75. test -f $back_path/$domain\_$TODAY\.zip && rm -f $back_path/$domain\_$TODAY\.zip
  76. $ZIP -P$mypassword -9r $back_path/$domain\_$TODAY\.zip $site_path && \
  77. uploadToCOS $domain $back_path/$domain\_$TODAY\.zip
  78. }
  79. while [ $1 ]; do
  80. case $1 in
  81. '--db' | 'db' )
  82. backupDB $2 $3 $4 $5 $6
  83. exit
  84. ;;
  85. '--file' | 'file' )
  86. backupFile $2 $3 $4
  87. exit
  88. ;;
  89. * )
  90. printHelp
  91. exit
  92. ;;
  93. esac
  94. done
  95. printHelp
②、使用方法

将上述代码作如下修改:

I、根据实际情况修改上述代码中的COS上传函数代码,比如密钥对和Bucket名称(参考前文)
II、替换代码中的mypassword=123456为自己设置的压缩包密码,不修改的话压缩文件解压密码为123456

然后,将代码保存为backup.sh,上传到服务器(建议存放到和前文python脚本的相同目录),比如/data/backup.sh,最后如下添加定时任务:

  1. #编辑crontab
  2. [root@AlyServer ~]# crontab -e
  3. #然后添加如下内容:
  4. #备份数据库(参数依次为:db、域名、数据库名称、数据库用户名、对应密码、备份路径 [可选:y 删除本地压缩包])
  5. 10 3 * * * bash /data/backup.sh db zhangge.net zhangge root 123456 /home/wwwbackup/zhangge.net > /dev/null 2>&1
  6. #备份网站文件(参数依次为:file、域名、网站根目录、备份路径 [可选:y 删除本地压缩包])
  7. 15 3 * * * bash /data/backup.sh file zhangge.net /home/wwwroot/zhangge.net /home/wwwbackup/zhangge.net >/dev/null 2>&1
  8. #按下键盘esc,输入 :wq 保存crontab即可

全部完成后,就能实现本地7天循环备份和COS远程备份了!

在文章的最后,为了方便广大代码小白朋友,特提供本文涉及脚本的打包下载:

五、幕后花絮

在折腾SDK的时候,第一眼其实被腾讯云的说明文档虐到了:

只说了如何安装SDK插件,然后直接来个def函数,然后就没然后了,到底如何import这个SDK?一脸懵逼。。。
最后在github的 simple.py 中才找到了完整的DEMO:
https://github.com/tencentyun/cos-python-sdk/blob/3.3/sample.py

在这懵逼期间,我甚至用上了腾讯云做好的本地迁移工具,实际也是非常好用,简单配置下就能在后台定时上传更新的文件到COS了:

篇幅有限,这里就不深入介绍了,除此之外,COS还提供了其他非常实用的工具,比如FTP工具、七牛以及OSS迁移工具等,感兴趣的朋友只需要看下 官方文档 就会弄了!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/501639
推荐阅读
相关标签
  

闽ICP备14008679号