一、基本介绍
cron是一个在Linux和Unix操作系统下用来进行周期性任务的程序。它可以在指定的时间周期性地运行某个命令或脚本。其中,一小时执行一次是常用的时间周期之一,我们需要对它进行深入了解。
二、基本使用方法
我们可以通过在终端输入“crontab -e”命令来编辑cron表,常规的cron表格式如下:
* * * * * command to be executed
- - - - -
| | | | |
| | | | +----- day of the week (0 - 6) (Sunday=0)
| | | +------- month (1 - 12)
| | +--------- day of the month (1 - 31)
| +----------- hour (0 - 23)
+------------- min (0 - 59)
其中,第1-5个字段表示分时日月周,以空格分隔的五个整数或通配符代表一次执行必备的时间信息,第6个字段表示要执行的命令。例如:“0 * * * * /root/test.sh”表示每小时执行一次/root/test.sh这个脚本。
三、时间设定技巧
为了更好地使用cron进行任务管理,需要一些时间设定的技巧。
1. 通配符的使用
在时间设定中,通配符*代表所有的取值范围,例如“* * * * *”表示每分钟执行一次。
2. 特殊取值的使用
cron中有一些特殊取值,如@hourly,@daily,@weekly等,它们分别代表每小时、每天、每周执行一次。比如,如果要让脚本在每天的凌晨2点运行,可以使用“0 2 * * *”或者“@midnight”。
3. 范围设定的使用
在时间设定的时候,可以使用-号表示范围,例如“10-20”表示从10到20。这在设定小时和分钟时很有用,比如“10 10-20 * * *”表示从早上10点到下午8点每小时都执行一次。
4. 步长设定的使用
在时间设定中,可以使用/号表示间隔,例如“*/5”表示每5分钟;“*/10”表示每隔10分钟。
四、实例
下面是一个cron一小时执行一次的例子,每隔一小时备份一下mysql数据库,保证数据安全。
0 * * * * /usr/bin/mysqldump -u username -ppassword dbname > /path/to/backup/folder/dbname-$(date +\%Y\%m\%d-\%H\%M).sql
五、注意事项
在使用cron时要注意以下几点:
1. 需要设置执行权限
在使用cron之前,需要给要执行的脚本或命令设置执行权限。可以通过“chmod +x filename”命令来赋予权限。
2. crontab文件的修改
修改crontab文件后,需要使用“service crond restart”重启服务,才能生效。如果你的操作系统不是CentOS,可以使用“service cron restart”。
3. 日志记录
cron执行的命令的输出结果不默认输出到终端,需要手动将stdout,stderr重定向到文件,如“0 * * * * /usr/bin/command > /path/to/stdout/file 2> /path/to/stderr/file"。通过查看这些文件可以有效的排查问题。
六、总结
在Linux和Unix系统下,使用cron完成周期性任务是非常方便和高效的。只要合理的设置时间和使用技巧,cron可以非常广泛的应用于各种系统管理和数据处理工作。希望这篇文章对你有所帮助。