1. 程式人生 > >mysql定時備份

mysql定時備份

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 -l //列出某個用戶cron服務的詳細內容
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定時備份