Linux中,周期执行的任务一般由cron这个守护进程来处理。cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。cron的配置文件称为“crontab”,是“cron table”的简写。在macOS中的用法一致。
1 相关命令
查看cron服务的状态:
sudo service cron status # * Usage: /etc/init.d/cron {start|stop|status|restart|reload|force-reload}
开启cron服务:
sudo /etc/init.d/cron start
关闭cron服务:
sudo /etc/init.d/cron stop
重启cron服务:
sudo /etc/init.d/cron restart
2 cron用法
crontab –e # 修改 crontab 文件,如果文件不存在会自动创建。 crontab –l # 显示 crontab 文件。 crontab -r # 删除 crontab 文件。 crontab -ir # 删除 crontab 文件前提醒用户。
在crontab文件中写入需要执行的命令和时间,该文件中每行都包括六个域,其中前五个域是指定命令被执行的时间,最后一个域是要被执行的命令。每个域之间使用空格或者制表符分隔。格式如下:
minute hour day-of-month month-of-year day-of-week commands
合法值为:00-59 00-23 01-31 01-12 0-6 (0 is sunday)
除了数字还有几个特殊的符号:”*”、”/”和”-“、”,”
- *代表所有的取值范围内的数字
- “/”代表每的意思,”/5″表示每5个单位
- “-“代表从某个数字到某个数字
- “,”分开几个离散的数字
注:commands 注意以下几点
- 要是存在文件,要写绝对路径
- 即使是打印也不会显示在显示屏,在后台运行,最好重定向日志
3 创建cron文件
EDITOR=vi export EDITOR crontab -e
4 实际例子
30 21 * * * lxc restart rognqi
意思是每到21点30分的时候就重启一下容器。
5 其他例子
每天早上6点 0 6 * * * echo "Good morning." >> /tmp/test.txt //注意单纯echo,从屏幕上看不到任何输出,因为cron把任何输出都email到root的信箱了。 每两个小时(第一个为15,指明没两个小时的第15min中执行一次) 15 */2 * * * echo "Have a break now." >> /tmp/test.txt 晚上11点到早上8点之间每两个小时和早上八点 0 23-7/2,8 * * * echo "Have a good dream" >> /tmp/test.txt 每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点 0 11 4 * 1-3 command line 1月1日早上4点 0 4 1 1 * command line 每小时(第一分钟)执行/etc/cron.hourly内的脚本 01 * * * * root run-parts /etc/cron.hourly 每天(凌晨4:02)执行/etc/cron.daily内的脚本 02 4 * * * root run-parts /etc/cron.daily 每星期(周日凌晨4:22)执行/etc/cron.weekly内的脚本 22 4 * * 0 root run-parts /etc/cron.weekly 每月(1号凌晨4:42)去执行/etc/cron.monthly内的脚本 42 4 1 * * root run-parts /etc/cron.monthly 注意: "run-parts"这个参数了,如果去掉这个参数的话,后面就可以写要运行的某个脚本名,而不是文件夹名。 每天的下午4点、5点、6点的5 min、15 min、25 min、35 min、45 min、55 min时执行命令。 5,15,25,35,45,55 16,17,18 * * * command 每周一,三,五的下午3:00系统进入维护状态,重新启动系统。 00 15 * *1,3,5 shutdown -r +5 每小时的10分,40分执行用户目录下的innd/bbslin这个指令: 10,40 * * * * innd/bbslink 每小时的1分执行用户目录下的bin/account这个指令: 1 * * * * bin/account
6 查看日志log
6.1 macOS
这是系统级别的日志,自动记录:
macOS:vi /var/mail/mcj
From mcj@machunjiedeMacBook-Pro.local Tue Jan 31 18:50:02 2023 Return-Path: <mcj@machunjiedeMacBook-Pro.local> X-Original-To: mcj Delivered-To: mcj@machunjiedeMacBook-Pro.local Received: by machunjiedeMacBook-Pro.local (Postfix, from userid 501) id 798D7C89602; Tue, 31 Jan 2023 18:50:02 +0800 (CST) From: mcj@machunjiedeMacBook-Pro.local (Cron Daemon) To: mcj@machunjiedeMacBook-Pro.local Subject: Cron <mcj@machunjiedeMacBook-Pro> /Users/mcj/GitCode/开机运行脚本/ipv6test_and_relogin.sh X-Cron-Env: <SHELL=/bin/sh> X-Cron-Env: <PATH=/usr/bin:/bin> X-Cron-Env: <LOGNAME=mcj> X-Cron-Env: <USER=mcj> Message-Id: <20230131105002.798D7C89602@machunjiedeMacBook-Pro.local> Date: Tue, 31 Jan 2023 18:50:02 +0800 (CST) 200 2023-01-31 18:50:02 第一次打开成功 200 2023-01-31 18:50:02 第一次打开成功 0 2
或者手动输出日志:
*/1 * * * * /Users/mcj/GitCode/开机运行脚本/ipv6test_and_relogin.sh > /Users/mcj/GitCode/开机运行脚本/ipv6test_and_relogin.log 2>&1
不过这个日志每次都会覆盖。如果不想覆盖,就把<
改成<<
*/1 * * * * /Users/mcj/GitCode/开机运行脚本/ipv6test_and_relogin.sh >> /Users/mcj/GitCode/开机运行脚本/ipv6test_and_relogin.log 2>&1
crontab
中1
表示正常的标准输出,2
表示错误输出。这里2>&1
表示错误信息也作为标准输出到该日志文件中
本文最后更新于2023年1月31日,已超过 1 年没有更新,如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢!