CentOS 7 Linux设置自动备份数据库到阿里云
环境:阿里云服务器CentOS7.4 + MySQL5.6基本思路:1、编写shell脚本,备份数据库到指定目录下2、编写Python脚本,把文件上传到OSS3、把shell脚本和Python脚本添加Linux的crontab定时器,设置定时执行首先,环境要配置好,Python环境,centos 7 自带Python,一般可以直接使用查看Python版本:python -Vhttps://www.linuxidc.com/upload/2018_05/180511203245471.png在创建一个目录/opt/backMySQL/xxx,在目录/opt/backMySQL下编写一个shell脚本backup.sh#!/bin/shcd /opt/backMySQL/xxx
echo "You are in /opt/backMySQL/xxx"Now=$(date +"%Y-%m-%d")
File=fileName-$Now.sql
mysqldump -urooot -ppassword databaseName > $File
echo "Your database backup successfully completed"
#删除昨天的文件
SevenDays=$(date -d -1day +"%Y-%m-%d")if [ -f /opt/backMySQL/xxx/fileName-$SevenDays.sql]
then
rm -rf /opt/backMySQL/xxx/fileName-$SevenDays.sql
echo "You have delete 1 tays ago bak file"
else
echo "1 days ago bak file not exist"
fi把第6、12、14行中的fileName替换成你想要的文件名,第7行换成数据库的用户和密码执行这个脚本,就可以把数据库备份到/opt/backMySQL/xxx目录下了再编写一个Python脚本backupToOSS.py# -I- coding: utf-8 -*-
import os
import oss2path = '/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) == '.sql':
fileName = i
bucket.put_object_from_file('remote.txt','content of object')注意:Python语言缩进有规定语法,不能随意缩进,记住缩进增加只用在以:结束的语句之后,缩进4个空格,而之后必须恢复到之前的缩进格式执行:python backupToOSS.py可以把文件上传到OSS上了设置定时器crontab -ehttps://www.linuxidc.com/upload/2018_05/180511203245472.png表示在每天1:05执行backup.sh、每天1:15执行backupToOSS.py
页:
[1]