mysql定時備份
-
創建備份目錄
$ cd ~ $ mkdir backup $ cd backup
-
創建備份 Shell 腳本:
vim DatabaseNameBackup.sh#!/bin/bash
mysqldump -uusername -ppassword DBName | gzip > ~/DBName$(date +%Y%m%d%H%M%S).sql.gz
註意:
把 username 替換為實際的用戶名;
把 password 替換為實際的密碼;
把 DBName 替換為實際的數據庫名; -
添加可執行權限
chmod u+x DatabaseNameBackup.sh - 直接編輯/etc/crontab 文件,即vi /etc/crontab,添加相應的任務。
crond
是linux用來定期執行程序的命令。當安裝完成操作系統之後,默認便會啟動此任務調度命令。crond命令每分鍾會定期檢查是否有要執行的工作,如果有要執行的工作便會自動執行該工作。可以用以下的方法啟動、關閉這個服務:
/sbin/service crond start //啟動服務
/sbin/service crond stop //關閉服務
/sbin/service crond restart //重啟服務
/sbin/service crond reload //重新載入配置
crontab命令選項
cron服務提供crontab命令來設定cron服務的,以下是這個命令的一些參數與說明:
crontab -u //設定某個用戶的cron服務,一般root用戶在執行這個命令的時候需要此參數
crontab -r //刪除沒個用戶的cron服務
crontab -e //編輯某個用戶的cron服務
比如說root查看自己的cron設置:crontab -u root -l
再例如,root想刪除fred的cron設置:crontab -u fred -r
在編輯cron服務時,編輯的內容有一些格式和約定,輸入:crontab -u root -e
定時任務例子
Crontab 的格式: 分 時 日 月 星期 要運行的命令
第 1 列分鐘 1~59 第 2 列小時 1~23(0 表示子夜) 第 3 列日 1~31 第 4 列月 1~12 第 5 列星期 0~6(0 表示星期天) 第 6 列要運行的命令
Crontab例子
5 * * * * ls //指定每小時的第5分鐘執行一次ls命令
30 5 * * * ls //指定每天的 5:30 執行ls命令
30 7 8 * * ls //指定每月8號的7:30分執行ls命令
30 5 8 6 * ls //指定每年的6月8日5:30執行ls命令
30 6 * * 0 ls //指定每星期日的6:30執行ls命令[註:0表示星期天,1表示星期1,以此類推,也可以用英文來表示,sun表示星期天,mon表示星期一等。]
30 3 10,20 * * ls //每月10號及20號的3:30執行ls命令[註:”,”用來連接多個不連續的時段]
25 8-11 * * * ls //每天8-11點的第25分鐘執行ls命令[註:”-”用來連接連續的時段]
*/15 * * * * ls //每15分鐘執行一次ls命令 [即每個小時的第0 15 30 45 60分鐘執行ls命令 ]
30 6 */10 * * ls //每個月中,每隔10天6:30執行一次ls命令[即每月的1、11、21、31日是的6:30執行一次ls命令。 ]
50 7 * * * root run-parts /etc/cron.daily //每天7:50以root 身份執行/etc/cron.daily目錄中的所有可執行文件[ 註:run-parts參數表示,執行後面目錄中的所有可執行文件。 ]
添加計劃任務
crontab -e
01 3 * * * root/home/backup/DatabaseName.sh
表示每天 3 點鐘執行備份
mysql定時備份