如何在linux环境下查看job运行时间 (linux查看job运行时间)

如何在Linux环境下查看Job运行时间

在Linux环境中,cron是一个经常使用的任务调度程序,可以设置定时运行的任务。当我们的Job被调度执行时,我们会想了解这个Job运行的时间以及执行的情况,这时候我们需要知道如何查看Job的运行时间。

以下是在Linux环境下查看Job运行时间的几种方法。

1. 使用command line查看Job的运行时间

我们可以在Linux中使用command line来查看Job的运行时间。具体步骤如下:

1. 打开terminal,并输入以下命令来打开cron的日志文件。

$ tl -f /var/log/syslog | grep CRON

2. 在terminal中,你会看到类似下面的内容:

Feb 12 20:45:01 ubuntu CRON[1234]: (root) CMD (/usr/bin/python /path/to/script.py)

这条命令显示了最近一个被执行的任务的信息,包括时间、任务的调用者以及命令的参数。

2. 查看/var/log/cron文件

另一个查看Job运行时间的方法是查看/var/log/cron文件。这个文件记录了每个任务的开始时间和结束时间。步骤如下:

1. 打开terminal,并输入以下命令来查看/var/log/cron文件。

$ cat /var/log/cron

2. 在打开的文件中,你会看到类似下面的内容:

Feb 12 20:45:01 ubuntu CRON[1234]: (root) CMD (/usr/bin/python /path/to/script.py)

这个文件显示了每个Job的开始时间和结束时间,通过对每行的时间打印,我们可以得出Job的开始时间和结束时间的差值,从而得到Job运行的时间。

3. 使用第三方工具

除了使用command line和查看/var/log/cron文件外,还可以使用第三方工具来查看Job的运行时间。cronolog是一款较为流行的日志文件管理工具,在cron调度的时候,可以将Job的运行时间自动记录到相应的日志文件中。通过该工具,我们可以查看每个Job的开始时间、结束时间和运行时间。

结论

以上是在Linux环境下查看Job运行时间的几种方法。我们可以根据任务的要求选择不同的查看方法。无论是使用command line,还是查看/var/log/cron文件,或者是使用第三方工具,我们都可以轻松地获取Job的运行时间和执行情况。

相关问题拓展阅读:

linux 远程主机后台运行任务 挂起脚本

背景

:工作需要,需要远程控制主机使其断开Xshell后也能一直运行。

关键字

:& ,nohup,脚本挂起。

在应用Unix/Linux时,我们一般想让某个程序在后台运行,于是我们将常会用 & 在程序结尾来让程序自动运行。

键入Ctrl + C,发出SIGINT信号陵世,程序会继续运行

方法一缺斗、输入命令:jobs

方法二:输入命令:ps

fg、bg、jobs、&、nohup、ctrl+z、ctrl+c

命令

加在一个命令的最后,可以把这个命令放到后台执行,如

可以将一个正在前台执行的命令放到后台,并且处于暂停状态。

查看当前有多少在后台运行的命令

jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated。但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识。

将后台中的命令调至前台继续运行。如果后台中有多个命令,可以用fg %jobnumber(是命令编号,不是进程号)将选中的命令调出。

将一个在后台暂停的命令,变成在后台继续执行。如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出。

法子1:通过jobs命令查看job号(假设为num),然后执行kill %num

法子2:通过ps命令查看job的进程号(PID,假设为pid),然后执行kill pid

前台进程的终止:Ctrl+c

如果让程序始终在后台执行,即使关闭当前的终端也执行(之前的&做不到),这时候需伏汪磨要nohup。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。

关闭中断后,在另一个终端jobs已经无法看到后台跑得程序了,此时利用ps(进程查看命令)

如上所示:

nohup 和 & 组合了后台运行程序。

可以输出到 out.log保存程序输出,也可以输出到/dev/null 即空设备,不保存输出。

上面三种方式无论在nohup.out 或test.out都看不到数据结果,这是因为python执行有缓存输出

解决

新的接口接入查看程序

使用&后台运行程序:

结果会输出到终端

使用Ctrl + C发送SIGINT信号,

程序免疫

关闭session发送SIGHUP信号,

程序关闭

使用nohup运行程序:

结果默认会输出到nohup.out

使用Ctrl + C发送SIGINT信号,

程序关闭

关闭session发送SIGHUP信号,

程序免疫

平日线上经常使用nohup和&配合来启动程序:

同时免疫SIGINT和SIGHUP信号

同时,还有一个更佳实践:

不要将信息输出到终端标准输出,标准错误输出,而要用日志组件将信息记录到日志里

nohup和&究竟有啥区别

linux查看job运行时间的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux查看job运行时间,如何在linux环境下查看job运行时间,linux 远程主机后台运行任务 挂起脚本的信息别忘了在本站进行查找喔。


数据运维技术 » 如何在linux环境下查看job运行时间 (linux查看job运行时间)