1. 程式人生 > >Linux(CentOS7)設置自動備份數據庫到阿裏雲OSS

Linux(CentOS7)設置自動備份數據庫到阿裏雲OSS

參考 .sql 自動 import itext text ner mil python語言

環境:阿裏雲服務器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語言縮進有規定語法,不能隨意縮進,記住縮進增加只用在以:結束的語句之後,縮進4個空格,而之後必須恢復到之前的縮進格式

執行:python backupToOSS.py

可以把文件上傳到OSS上了

設置定時器 crontab -e 技術分享圖片 表示在每天1:05執行backup.sh、每天1:15執行backupToOSS.py 定時具體設置參考 http://www.osyunwei.com/archives/5039.html Linux定時執行Python腳本 https://www.cnblogs.com/zichun-zeng/p/4235585.html

Linux(CentOS7)設置自動備份數據庫到阿裏雲OSS