Crontab 每天定时备份 MySQL
2015-08-13 17:31
531 查看
1、创建shell脚本
# vim /usr/mysql_backup.sh
#!/bin/bash
back_dir=/usr/mysql-backup
back_date=`date +%F`
user=root
pass=123456
dbname=test
if [ ! -d ${back_dir} ];then
mkdir -p /${back_dir}
fi
/usr/local/mysql/bin/mysqldump -u${user} -p${pass} ${dbname} > ${back_dir}/${back_date}_${dbname}.sql
crontab脚本中命令和路径都使用绝对路径,不然会造成虽然crontab执行,但是没有任何结果。
2、修改脚本权限
# chmod +x /usr/mysql_backup.sh
3、测试shell脚本# /usr/mysql_backup.sh
如果有waring警告,可以忽略
4、修改/etc/crontab
#vi /etc/crontab
或者
#crontab -e
在下面添加
00 8 * * * /usr/mysql_backup.sh
5、重新启动 crond (可有可无,在步骤4,保存后,命令就生效了)
# /etc/rc.d/init.d/crond restart
注:
1、任务调度设置文件的写法 可用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命令 ]
3 0 6 */10 * * ls 每个月中,每隔10天6:30执行一次ls命令[即每月的1、11、21、31日是的6:30执行一次ls 命令。 ]
每天7:50以root 身份执行/etc/cron.daily目录中的所有可执行文件
50 7 * * * root run-parts /etc/cron.daily
[ 注:run-parts参数表示,执行后面目录中的所有可执行文件。 ]
# vim /usr/mysql_backup.sh
#!/bin/bash
back_dir=/usr/mysql-backup
back_date=`date +%F`
user=root
pass=123456
dbname=test
if [ ! -d ${back_dir} ];then
mkdir -p /${back_dir}
fi
/usr/local/mysql/bin/mysqldump -u${user} -p${pass} ${dbname} > ${back_dir}/${back_date}_${dbname}.sql
crontab脚本中命令和路径都使用绝对路径,不然会造成虽然crontab执行,但是没有任何结果。
2、修改脚本权限
# chmod +x /usr/mysql_backup.sh
3、测试shell脚本# /usr/mysql_backup.sh
如果有waring警告,可以忽略
4、修改/etc/crontab
#vi /etc/crontab
或者
#crontab -e
在下面添加
00 8 * * * /usr/mysql_backup.sh
5、重新启动 crond (可有可无,在步骤4,保存后,命令就生效了)
# /etc/rc.d/init.d/crond restart
注:
1、任务调度设置文件的写法 可用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命令 ]
3 0 6 */10 * * ls 每个月中,每隔10天6:30执行一次ls命令[即每月的1、11、21、31日是的6:30执行一次ls 命令。 ]
每天7:50以root 身份执行/etc/cron.daily目录中的所有可执行文件
50 7 * * * root run-parts /etc/cron.daily
[ 注:run-parts参数表示,执行后面目录中的所有可执行文件。 ]
相关文章推荐
- MySql 定时任务 Event Scheduler
- 11步教你选择最稳定的MySQL版本
- MySQL 存储引擎 MyISAM 与 InnoDB 的对比
- mysql的event坑
- MYSQL中取当前年份的第一天和当前周,月,季度的第一天/最后一天
- MySQL 5.6 中的 TIMESTAMP 和 explicit_defaults_for_timestamp 参数
- MYSQL主从表插入,使用存储过程
- MySQL视图
- MySQL Study之--MySQL innodb引擎表存储分析
- Mysql 分页
- mysql源码安装
- mysql忘记密码
- mysql引擎分析说明整理
- mysql数据库的连接
- MySQL数据备份
- MySQL中group_concat函数-和group by配合使用
- MySQL数据库迁移(直接复制文件)
- 配置MySQL主从复制(Replication)
- MySQL常见命令和操作一览
- mysql隔离级别