阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

CentOS 7 Linux设置自动备份数据库到阿里云OSS

124次阅读
没有评论

共计 1292 个字符,预计需要花费 4 分钟才能阅读完成。

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

基本思路:

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

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

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

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

查看 Python 版本:python -V

CentOS 7 Linux 设置自动备份数据库到阿里云 OSS

在创建一个目录 /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

CentOS 7 Linux 设置自动备份数据库到阿里云 OSS

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

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-21发表,共计1292字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中