1. 程式人生 > 實用技巧 >docker下mysql定時任務備份及遇到問題

docker下mysql定時任務備份及遇到問題

備份mysql

注:部分為網上找到,後面加以修改。

建立指令碼

命令:vi mysql_backup.sh
內容如下:

#!/bin/bash
# 設定mysql的登入使用者名稱和密碼(根據實際情況填寫)
mysql_user="root"
mysql_password="123456"
mysql_host="localhost"
mysql_port="3306"
mysql_charset="utf8mb4"
 
# 備份檔案存放地址(根據實際情況填寫)
backup_location=/usr/local
 
# 是否刪除過期資料
expire_backup_delete="ON"
expire_days=7
backup_time=`date +%Y%m%d%H%M`
backup_dir=$backup_location
welcome_msg="Welcome to use MySQL backup tools!"



# 備份指定資料庫中資料(此處我要備份的資料庫為longxing)
docker exec -i mymysql mysqldump -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password -B longxing > $backup_dir/$backup_time.sql


 
# 刪除過期資料
if [ "$expire_backup_delete" == "ON" -a  "$backup_location" != "" ];then
        `find $backup_location/ -type f -mtime +$expire_days | xargs rm -rf`
        echo "Expired backup data delete complete!"
fi

**注 在上面執行命令時一定不能為docker exec -it 不然執行任務時會出現:the input device is not a TTY錯誤 **
執行以下命令:

chmod u+x *.sh

建立定時任務

命令: crontab -e
在編輯框輸入:

09 11 * * * cd /home/dbback;sh mysql_backup.sh >> log.txt 2>>log.txt

這邊做下注釋:前面時間表示任務啟動時間為11點09分。指令碼位置為:/home/dbback目錄下。後面就不用說了。

最終執行結果:

本文由部落格群發一文多發等運營工具平臺

OpenWrite 釋出