Linux中,周期执行的任务一般由cron这个守护进程来处理。cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间。cron的配置文件称为“crontab”,是“cron table”的简写。在macOS中的用法一致。
1 相关命令
查看cron服务的状态:
1 2 |
sudo service cron status # * Usage: /etc/init.d/cron {start|stop|status|restart|reload|force-reload} |
开启cron服务:
1 |
sudo /etc/init.d/cron start |
关闭cron服务:
1 |
sudo /etc/init.d/cron stop |
重启cron服务:
1 |
sudo /etc/init.d/cron restart |
2 cron用法
1 2 3 4 |
crontab –e # 修改 crontab 文件,如果文件不存在会自动创建。 crontab –l # 显示 crontab 文件。 crontab -r # 删除 crontab 文件。 crontab -ir # 删除 crontab 文件前提醒用户。 |
在crontab文件中写入需要执行的命令和时间,该文件中每行都包括六个域,其中前五个域是指定命令被执行的时间,最后一个域是要被执行的命令。每个域之间使用空格或者制表符分隔。格式如下:
1 |
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文件
1 2 3 |
EDITOR=vi export EDITOR crontab -e |
4 实际例子
1 |
30 21 * * * lxc restart rognqi |
意思是每到21点30分的时候就重启一下容器。
5 其他例子
6 查看日志log
6.1 macOS
这是系统级别的日志,自动记录:
macOS:vi /var/mail/mcj
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
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
表示错误信息也作为标准输出到该日志文件中