linux下使用crontab定時備份MYSQL數據庫的方法

第一步:在linux服務器下新建一個MYSQL數據庫備份的文件夾mysql

-------------------------------------------------------------------------------- linux

mkdir /mysql_backup   能夠在任何目錄上新建文件夾sql

-------------------------------------------------------------------------------- 數據庫

第二步:切換到建立的文件夾下面,編寫備份腳本代碼服務器

-------------------------------------------------------------------------------- 命令行

cd /mysql_backup 切換到剛剛新建的文件夾crontab

vi db_backup.sh   編寫備份腳本代碼ip

-------------------------------------------------------------------------------- date

務必更改其中的username,password和dbname。 權限

#!/bin/sh

mysqldump -uuser -ppassword dbname | gzip > /mysql_backup/dbname`date +%Y-%m-%d_%H%M%S`.sql.gz

cd  /mysql_backup

   rm -rf `find . -name '*.sql.gz' -mtime 5`  #刪除5天前的備份文件

-------------------------------------------------------------------------------- 

第三步:更改備份腳本權限  

-------------------------------------------------------------------------------- 

chmod +x dbbackup.sh 或者 chmod 777 dbbackup.sh

-------------------------------------------------------------------------------- 

第四步:用crontab定時執行備份腳本代碼: 

-------------------------------------------------------------------------------- 

crontab -e 

若天天晚上凌晨4點備份備份,添加以下代碼, 

00 04 * * * /mysql_backup/db_backup.sh

-------------------------------------------------------------------------------- 

注:

一、任務調度設置文件的寫法
      可用crontab -e命令來編輯,編輯的是/var/spool/cron下對應用戶的cron文件,也能夠直接修改/etc/crontab文件
     具體格式以下:
      Minute Hour Day Month Dayofweek   command
      分鐘     小時   天     月       天每星期       命令
     每一個字段表明的含義以下:
     Minute             每一個小時的第幾分鐘執行該任務
     Hour               天天的第幾個小時執行該任務
     Day                 每個月的第幾天執行該任務
     Month             每一年的第幾個月執行該任務
     DayOfWeek     每週的第幾天執行該任務
     Command       指定要執行的程序
     在這些字段裏,除了「Command」是每次都必須指定的字段之外,其它字段皆爲可選

    字段,可視須要決定。對於不指定的字段,要用「*」來填補其位置。
    舉例以下:
    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命令[即每個月的一、十一、2一、31日是的6:30執行一次ls 命令。 ]

     天天7:50以root 身份執行/etc/cron.daily目錄中的全部可執行文件

     50   7       *             *     *     root     run-parts     /etc/cron.daily   [ 注:run-parts參數表示,執行後面目錄中的全部可執行文件。 ]

二、新增調度任務可用兩種方法:        1)、在命令行輸入: crontab -e 而後添加相應的任務,wq存盤退出。         2)、直接編輯/etc/crontab 文件,即vi /etc/crontab,添加相應的任務。

相關文章
相關標籤/搜索