600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > mysql数据库备份oss_Linux(CentOS7)设置自动备份数据库到阿里云OSS(示例代码)

mysql数据库备份oss_Linux(CentOS7)设置自动备份数据库到阿里云OSS(示例代码)

时间:2020-12-12 00:09:38

相关推荐

mysql数据库备份oss_Linux(CentOS7)设置自动备份数据库到阿里云OSS(示例代码)

环境:阿里云服务器CentOS7.4 + MySQL5.6

基本思路:

1、编写shell脚本,备份数据库到指定目录下

2、编写Python脚本,把文件上传到OSS

3、把shell脚本和Python脚本添加Linux的crontab定时器,设置定时执行

首先,环境要配置好,Python环境,centos 7 自带Python,一般可以直接使用

查看Python版本:python -V

在创建一个目录/opt/backMySQL/xxx,在目录/opt/backMySQL下编写一个shell脚本backup.sh

1 #!/bin/sh

2 cd /opt/backMySQL/xxx3 echo "You are in /opt/backMySQL/xxx"

4

5 Now=$(date +"%Y-%m-%d")6 File=fileName-$Now.sql7 mysqldump -urooot -ppassword databaseName >$File8 echo "Your database backup successfully completed"

9 #删除昨天的文件

10 SevenDays=$(date -d -1day +"%Y-%m-%d")11

12 if [ -f /opt/backMySQL/xxx/fileName-$SevenDays.sql ]13 then14 rm -rf /opt/backMySQL/xxx/fileName-$SevenDays.sql15 echo "You have delete 1 tays ago bak file"

16 else

17 echo "1 days ago bak file not exist"

18 fi

把第6、12、14行中的fileName替换成你想要的文件名,第7行换成数据库的用户和密码

执行这个脚本,就可以把数据库备份到/opt/backMySQL/xxx目录下了

再编写一个Python脚本backupToOSS.py

#-I- coding: utf-8 -*-

importosimportoss2

path= ‘/opt/backMySQL/naner_zhongkong/‘auth= oss2.Auth(‘您的AccessKeyId‘,‘您的AccessKeySecret‘)

bucket= oss2.Bucket(auth,‘您的Endpoint‘,‘您的Bucket名‘)#获取目录下的所有文件

f_list =os.listdir(path)for i inf_list:#os.path.splitext():分离文件名与扩展名

if os.path.splitext(i)[1] == ‘.sql‘:

fileName=i

bucket.put_object_from_file(‘remote.txt‘,‘content of object‘)

注意:Python语言缩进有规定语法,不能随意缩进,记住缩进增加只用在以:结束的语句之后,缩进4个空格,而之后必须恢复到之前的缩进格式

执行:python backupToOSS.py

可以把文件上传到OSS上了

设置定时器

crontab -e

表示在每天1:05执行backup.sh、每天1:15执行backupToOSS.py

定时具体设置参考

Linux定时执行Python脚本

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。