马春杰杰 Exit Reader Mode

macOS/Ubuntu系统定时执行bashshell命令|macOS/Ubuntu定时执行指定脚本

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) 

除了数字还有几个特殊的符号:”*”、”/”和”-“、”,”

: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

crontab1表示正常的标准输出,2表示错误输出。这里2>&1表示错误信息也作为标准输出到该日志文件中

本文最后更新于2023年1月31日,已超过 1 年没有更新,如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢!