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,添加相应的任务。

相关文章
相关标签/搜索