CentOS7Linux设置自动备份数据库到阿里云OSS

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

创新互联成立10多年来,这条路我们正越走越好,积累了技术与客户资源,形成了良好的口碑。为客户提供成都做网站、网站设计、网站策划、网页设计、国际域名空间、网络营销、VI设计、网站改版、漏洞修补等服务。网站是否美观、功能强大、用户体验好、性价比高、打开快等等,这些对于网站建设都非常重要,创新互联通过对建站技术性的掌握、对创意设计的研究为客户提供一站式互联网解决方案,携手广大客户,共同发展进步。

基本思路:

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

#!/bin/sh
cd /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 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语言缩进有规定语法,不能随意缩进,记住缩进增加只用在以:结束的语句之后,缩进4个空格,而之后必须恢复到之前的缩进格式

执行:python backupToOSS.py

可以把文件上传到OSS上了

设置定时器

crontab -e

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

分享标题:CentOS7Linux设置自动备份数据库到阿里云OSS
URL分享:http://www.mswzjz.com/qtweb/news1/169201.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联