标签:分享图片 .sh bin date odi object bsp arch color
环境:阿里云服务器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/xxx 3 echo "You are in /opt/backMySQL/xxx" 4 5 Now=$(date +"%Y-%m-%d") 6 File=fileName-$Now.sql 7 mysqldump -urooot -ppassword databaseName > $File 8 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 then 14 rm -rf /opt/backMySQL/xxx/fileName-$SevenDays.sql 15 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 -*- import os import oss2 path = ‘/opt/backMySQL/naner_zhongkong/‘ auth = oss2.Auth(‘您的AccessKeyId‘,‘您的AccessKeySecret‘) bucket = oss2.Bucket(auth,‘您的Endpoint‘,‘您的Bucket名‘) #获取目录下的所有文件 f_list = os.listdir(path) for i in f_list: # os.path.splitext():分离文件名与扩展名 if os.path.splitext(i)[1] == ‘.sql‘: fileName = i bucket.put_object_from_file(‘remote.txt‘,‘content of object‘)
执行:python backupToOSS.py
可以把文件上传到OSS上了
Linux(CentOS7)设置自动备份数据库到阿里云OSS
标签:分享图片 .sh bin date odi object bsp arch color
原文地址:https://www.cnblogs.com/guodong-wei/p/9025466.html