crontab && history查看命令的执行时间

2 篇文章 0 订阅

crontab

crontab学习网站(19. crontab 定时任务 — Linux Tools Quick Tutorial

例子

今天实际工作里用到的(已经进行了防信息泄露处理

比如我现在希望每周三上午10:00之行一个php脚本

--gpt生成

00 10 * * 3 cd /home/user/project/risk && /usr/local/bin/php sendCheckVersionInfoRiskTagEmail.php > sendCheckVersionInfoRiskTagEmail.log 2>&1

  1. 00 10 * * 3: 这是 cron 作业的时间表达式,指定了作业运行的时间。这表示在每周的周三的上午 10:00 执行作业。

  2. cd /home/user/project/risk: 这一行是改变工作目录到指定的路径。在这里,它将工作目录切换到 /home/user/project/risk

  3. &&: 这是逻辑运算符 "AND",表示只有当前一个命令成功执行后才执行下一个命令。

  4. /usr/local/bin/php sendCheckVersionInfoRiskTagEmail.php: 这是要执行的命令,它会运行一个 PHP 脚本文件 sendCheckVersionInfoRiskTagEmail.php。在这里,它使用了 PHP 解释器 /usr/local/bin/php 来执行这个脚本。

  5. > sendCheckVersionInfoRiskTagEmail.log 2>&1: 这部分是输出重定向的语法,将命令的标准输出重定向到 sendCheckVersionInfoRiskTagEmail.log 文件中,并将标准错误输出(2)重定向到标准输出(1),这样可以将标准错误输出也写入到同一个日志文件中。

因此,这段代码的作用是在每周三的上午 10:00,切换工作目录到 /home/user/project/risk 目录,并执行一个 PHP 脚本 sendCheckVersionInfoRiskTagEmail.php,将执行过程的输出记录到日志文件中。

crontab详解
概述

通过crontab 命令,我们可以在固定的间隔时间执行指定的系统指令或 shell script脚本。时间间隔的单位可以是分钟、小时、日、月、周及以上的任意组合。这个命令非常适合周期性的日志分析或数据备份等工作。

主要就是定时地执行某个脚本,而不需要耗费大量人力重复性执行

crontab命令格式
  • crontab [-u user] file crontab [-u user] [ -e | -l | -r ]

命令参数

注:其实实际工作时,都是公用的crontab文件,基本上用crontab -e就够了,修改crontab文件内容

  • -u user:用来设定某个用户的crontab服务;

  • file:file是命令文件的名字,表示将file做为crontab的任务列表文件并载入crontab。如果在命令行中没有指定这个文件,crontab命令将接受标准输入(键盘)上键入的命令,并将它们载入crontab。

  • -e:编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前用户的crontab文件。

  • -l:显示某个用户的crontab文件内容,如果不指定用户,则表示显示当前用户的crontab文件内容。

  • -r:从/var/spool/cron目录中删除某个用户的crontab文件,如果不指定用户,则默认删除当前用户的crontab文件。

  • -i:在删除用户的crontab文件时给确认提示。

crontab实际调用脚本的命令格式

分 时 日 月 星期 要运行的命令

(比如最上方举的例子:00 10 * * 3: 这是 cron 作业的时间表达式,指定了作业运行的时间。这表示在每周的周三的上午 10:00 执行作业。)

  • 第1列分钟0~59

  • 第2列小时0~23(0表示子夜)

  • 第3列日1~31

  • 第4列月1~12

  • 第5列星期0~7(0和7表示星期天)

  • 第6列要运行的命令

实例

实例1:每1分钟执行一次myCommand

*****myCommand

实例2:每小时的第3和第15分钟执行

3,15****myCommand

实例3:在上午8点到11点的第3和第15分钟执行

3,158-11***myCommand

实例4:每隔两天的上午8点到11点的第3和第15分钟执行

3,158-11*/2**myCommand

实例5:每周一上午8点到11点的第3和第15分钟执行

3,158-11**1myCommand

实例6:每晚的21:30重启smb

3021***/etc/init.d/smbrestart

实例7:每月1、10、22日的4 : 45重启smb

4541,10,22**/etc/init.d/smbrestart

实例8:每周六、周日的1 : 10重启smb

101**6,0/etc/init.d/smbrestart

实例9:每天18 : 00至23 : 00之间每隔30分钟重启smb

0,3018-23***/etc/init.d/smbrestart

实例10:每星期六的晚上11 : 00 pm重启smb

023**6/etc/init.d/smbrestart

实例11:每一小时重启smb

**/1***/etc/init.d/smbrestart

实例12:晚上11点到早上7点之间,每隔一小时重启smb

023-7***/etc/init.d/smbrestart

注意事项
  • 新创建的cron job,不会马上执行,至少要过2分钟才执行。如果重启cron则马上执行。

  • 当crontab失效时,可以尝试/etc/init.d/crond restart解决问题。或者查看日志看某个job有没有执行/报错tail -f /var/log/cron。-

  • 千万别乱运行crontab -r。它从Crontab目录(/var/spool/cron)中删除用户的Crontab文件。删除了该用户的所有crontab都没了。

  • 注意时区,在终端中使用date命令查看时区,如果时区不一致的话,会导致脚本运行的时间和你预想的不一致

  • 在crontab中%是有特殊含义的,表示换行的意思。如果要用的话必须进行转义%,如经常用的date ‘+%Y%m%d’在crontab里是不会执行的,应该换成date ‘+%Y%m%d’。

history查看命令的执行时间

这个指的是,我们使用history本来只能看到命令序号和具体用过什么命令,而不知道这个命令发生的时间,在进行一些溯源时比较麻烦

之所以想去了解这个东西,是因为今天mt说因为我早上写需求的时候没pull最新的代码,加上我自己的然后就提交了,导致他的代码被覆盖

为了确定我早上是否进行了拉取最新代码的操作,我就去查了一下history怎么显示出命令发生的时间。

->

mac设置方式 :

echo'HISTTIMEFORMAT="%F %T "' >> ~/.bashrc

source ~/.bashrc

如果使用了zsh环境的终端(比如我):

使用history -i

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值