mysqldump -u root -p 数据库名 表名 > 位置
mysqldump -u root -p sys_user user > /home/whch/user.bak
mysqldump -u root -p sys_user user < /home/whch/user.bak
mysql -u用户名 -p密码 < 要导入的数据库数据(runoob.sql)
# mysql -u root -p 123456 < runoob.sql
* * * * * command path // 前五个字段可以取整数值,指定何时开始工作,第六个域是字符串,即命令字段,其中包括了crontab调度执行的命令。 各个字段之间用spaces和tabs分割。
字段名称 | 说明 | 取值范围 |
分钟 | 每小时的第几分钟执行 | 0-59 |
小时 | 每日的第几个小时执行 | 0-23 |
日期 | 每月的第几天执行 | 1-31 |
月历 | 每年的第几月执行 | 1-12 |
星期 | 每周的第几天执行 | 0-6 |
命令名称 | 欲执行的命令及参数 |
crontab命令中的一些常用特殊符号:
符号 | 说明 |
* | 表示任何时刻 |
, | 表示分割 |
- | 表示一个段,如第二段里: 1-5,就表示1到5点 |
/n | 表示每个n的单位执行一次,如第二段里,*/1, 就表示每隔1个小时执行一次命令。也可以写成1-23/1. |
每天定时执行任务,配置样例如下:
8,12,16 * * * /data/app/scripts/monitor/df.sh
2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh
8,12,16 * * * /data/app/scripts/monitor/check_ind_unusable.sh
8,12,16 * * * /data/app/scripts/monitor/check_maxfilesize.sh
8,12,16 * * * /data/app/scripts/monitor/check_objectsize.sh
21 * * * 每天的21:43 执行
05 * * * 每天的05:15 执行
17 * * * 每天的17:00 执行
17 * * 1 每周一的 17:00 执行
0,10 17 * * 0,2,3 每周日,周二,周三的 17:00和 17:10 执行
0-10 17 1 * * 毎月1日从 17:00到7:10 毎隔1分钟 执行
0 1,15 * 1 毎月1日和 15日和 一日的 0:00 执行
4 1 * * 毎月1日的 4:42分 执行
21 * * 1-6 周一到周六 21:00 执行
0,10,20,30,40,50 * * * * 每隔10分 执行
*/10 * * * * 每隔10分 执行
* 1 * * * 从1:0到1:59 每隔1分钟 执行
1 * * * 1:00 执行
*/1 * * * 毎时0分 每隔1小时 执行
* * * * 毎时0分 每隔1小时 执行
8-20/3 * * * 8:02,11:02,14:02,17:02,20:02 执行
5 1,15 * * 1日 和 15日的 5:30 执行
一种执行contrab -e 下执行,在后面再追加一个命令即可,不推荐。
另一种在脚本中部署任务执行,推荐,在task.sh下输入命令,每天凌晨两点执行备份某数据库文件.日期格式:
# 2018-12-24 11:22:44 echo `date "+%Y-%m-%d %H:%M:%S"`
echo $(date +%Y-%m-%d %H:%M:%S) #与上等同
#压缩与不压缩 二选一
#!/bin/bash
mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql
#!/bin/bash
mysqldump -uusername -ppassword DatabaseName | gzip > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql.gz
username和password替换为自己的MySQL账号和密码,中间没有空格,然后部署任务:
chmod 744 task.sh
crontab -e
>2 * * * /task.sh
五、crontab的其他一些命令
如果我们需要列出自己创建的任务调度都有哪些命令,可以使用 crontab -l 命令来查看
[root@xiaoluo /]# crontab -l
2 * * * /task.sh
如果我们需要终止自己刚创建的任务调度,则使用 crontab -r 命令即可
[root@xiaoluo /]# crontab -r
此时我们可以发现,crontab里面的任务都已经没有了
六、cron服务的启动
我们可以通过 chkconfig --list | grep cron 命令来查看cron服务的启动情况:
[root@xiaoluo home]# chkconfig --list | grep cron
crond 0:关闭 1:关闭 2:启用 3:启用 4:启用 5:启用 6:关闭
我们可以看到,系统启动级别如果是1-4,cron服务都会开机自动启动的,我们可以通过如下命令来设置该服务的启动项:
/sbin/service crond start
/sbin/service crond stop
/sbin/service crond restart
/sbin/service crond reload
以上1-4行分别为启动、停止、重启服务和重新加载配置。
要把cron设为在开机的时候自动启动,在 /etc/rc.d/rc.local 脚本中加入 /sbin/service crond start 即可。