##一、介绍
1、cron是一个Linux定时执行工具,可以在无需人工干预的情况下运行作业。在ubuntu server 下,cron是被默认安装并启动的,默认安装目录:/etc/crontab
2、要实现定时任务,首先要了解cron的各种命令,cron服务的启动与停止
1、service cron start /
启动服务
/
2、service cron stop /关闭服务
/
3、service cron restart /重启服务
/
4、service cron reload /重新载入配置
/
3、可以通过以下命令查看cron是否在运行(如果在运行,则会返回一个进程ID):
pgrep cron,如图:
4、crontab命令的认识
crontab命令用于安装、删除或者列出用于驱动cron后台进程的表格。也就是说,用户把需要执行的命令序列放到crontab文件中以获得执行,每个用户都可以有自己的crontab文件。以下是这个命令的一些参数与说明:
1、crontab -u /
设定某个用户的cron服务
/
2、crontab -l /列出某个用户cron服务的详细内容
/
3、crontab -r /删除某个用户的cron服务
/
4、crontab -e /编辑某个用户的cron服务
/
5、参数名称含义
-l 显示用户的Crontab文件的内容 crontabl –l
-i 删除用户的Crontab文件前给提示 crontabl -ri
-r 从Crontab目录中删除用户的Crontab文件 crontabl -r
-e 编辑用户的Crontab文件 crontabl -e
/etc/crontab文件语法如下:
Minute Hour Day Month Dayofweek command
分钟 小时 天 月 天每星期 命令
每个字段代表的含义及取值范围如下:
Minute :分钟(0-59),表示每个小时的第几分钟执行该任务
Hour : 小时(1-23),表示每天的第几个小时执行该任务
Day : 日期(1-31),表示每月的第几天执行该任务
Month : 月份(1-12),表示每年的第几个月执行该任务
DayOfWeek : 星期(0-6,0代表星期天),表示每周的第几天执行该任务
Command : 指定要执行的命令(如果要执行的命令太多,可以把这些命令写到一个脚本里面,然后在这里直接调用这个脚本就可以了,调用的时候记得写出命令的完整路径)
在这些字段里,除了“Command”是每次都必须指定的字段以外,其它字段皆为可选字段,可视需要决定。对于不指定的字段,要用“*”来填补其位置。同时,cron支持类似正则表达式的书写,支持如下几个特殊符号定义:
“*” ,代表所有的取值范围内的数字;
“/” , 代表”每”(“*/5”,表示每5个单位);
“-” , 代表从某个数字到某个数字(“1-4”,表示1-4个单位);
“,” ,分开几个离散的数字;
1234
举例如下:
5 * * * * ls /*指定每小时的第5分钟执行一次ls命令*/
30 5 * * * ls /*指定每天的 5:30 执行ls命令*/
30 7 8 * * ls /*指定每月8号的7:30分执行ls命令*/
50 7 * * * root run-parts /etc/cron.daily /*每天7:50以root 身份执行/etc/cron.daily目录中的所有可执行文件*/
1234
##二、测试,创建一个定时任务:每分钟往一个文件中写入"helloword!"
1、进入系统根目录:cd /tmp,再跑:touch cron_log.txt, 执行crontab -e,在最底下写入如下代码:
* * * * * echo "Hello world!" >> /tmp/cron_log.txt
1
2、由于每个用户的定时任务都在/var/spool/cron/crontabs目录下有个与用户名一致的任务文件,因此也可以通过vim直接编辑:vim /var/spool/cron/crontabs/root #注:root为当前用户名
同样在文件末行插入如下代码:
* * * * * echo "Hello world!" >> /tmp/cron_log.txt
1
保存退出,同时重启cron服务:
service cron start
1
等一分钟,通过FZ软件,查看/tmp/cron_log.txt,“Hello world!”每隔一分钟输出一次
最后关闭服务:service cron stop
##三、实现定时备份数据库
1、先写一个sh脚本任务,定时往某个文件中备份数据库,执行如下命令:
cd /home/ubuntu
mkdir data_backup
vim mysqlbackup.sh
123
写上如下代码:
#!/bin/bash
date_str=$(date +%Y%m%d-%T)
cd /home/ubuntu/data_backup
mysqldump -h 127.0.0.1 -u root --password=canon4ever -R -E -e wechat > /home/ubuntu/data_backup/$date_str.sql
1234
保存退出:wq。
2、进入脚本所在文件夹下为脚本文件授权,命令如下
chmod +x mysqlbackup.sh
1
3、在脚本所在文件夹下进行检验是否成功备份,命令如下:
./mysqlbackup.sh
1
测试:看看data_backup下是否有备份文件,如果成功备份就接下来创建定时执行文件。
成功后,删除备份文件即可。
2、配置自动执行脚本,任意目录执行crontab -e,在最底下加入如下代码:
* * * * * sh /home/ubuntu/data_backup/mysqlbackup.sh #每分钟执行一次数据库备份,时间可根据实际需求设置
1
3、重启服务
service cron restart
1
4、查看/home/ubuntu/data_backup里面是不是每分钟都执行一次备份:如图