在类 Unix 系统中上次运行 cron 作业的详细信息?

Posted

技术标签:

【中文标题】在类 Unix 系统中上次运行 cron 作业的详细信息?【英文标题】:Details of last ran cron job in Unix-like systems? 【发布时间】:2012-06-23 07:03:27 【问题描述】:

我想获取上次运行 cron 作业的详细信息。如果作业由于某些内部问题而中断,我想重新运行 cron 作业。

注意:我没有超级用户权限。

【问题讨论】:

【参考方案1】:

CentO, sudo grep CRON /var/log/cron

【讨论】:

甚至更好sudo grep CRON /var/log/cron | grep \(user\)【参考方案2】:

您可以使用以下命令查看之前执行的 cron 作业的日期、时间、用户和命令:

grep CRON /var/log/syslog

这将显示 所有 cron 作业。如果您只想查看某个用户运行的作业,您可以使用以下内容:

grep CRON.*\(root\) /var/log/syslog

请注意,作业开始时的 cron 日志,因此您可能希望冗长的作业保留自己的完成日志;如果系统在作业中途出现故障,它仍然会在日志中!

编辑:如果您没有 root 访问权限,则必须保留自己的工作日志。这可以简单地通过将以下内容添加到作业命令的末尾来完成:

&& date > /home/user/last_completed

文件/home/user/last_completed 将始终包含作业完成的最后日期和时间。如果您想将完成日期附加到文件中,您可以使用 >> 而不是 >

您也可以通过将您的命令放入一个小的 bash 或 sh 脚本中并让 cron 执行该文件来实现同样的目的。

#!/bin/bash
[command]
date > /home/user/last_completed

为此的 crontab 将是:

* * * * * bash /path/to/script.bash

【讨论】:

有没有办法以root用户权限查看详细信息。因为我没有root权限。 您需要让您的作业保留自己的完成日志。编辑显示示例。 这个答案是否适用于以 root 身份运行的 cron 作业以及以我的本地用户身份运行的作业? @Richard - 是的,Cron 会在 syslog 中记录所有用户的作业(至少在 Debian 下):sudo grep CRON /var/log/syslog 以查看它们,或者将 root 替换为您希望从中查看作业的用户我的答案中的第二个命令。 我的 CentOS 上没有 syslog 路径,但它直接在 /var/log/cron 文件中【参考方案3】:

/var/log/cron 包含 cron 作业日志。但是你需要root权限才能看到。

【讨论】:

我在路径 /var/log/ 上看不到任何名称为 cron 的文件或目录 我认为答案应该明确说明它们与什么分布相关!!!

以上是关于在类 Unix 系统中上次运行 cron 作业的详细信息?的主要内容,如果未能解决你的问题,请参考以下文章

如何确保 cron 作业能够运行?

通过 Cron 作业交替使用 linux 脚本 [关闭]

Linux/UNIX 定时任务 cron 详解

如何指示 cron 每两周执行一次作业?

如何设置系统来告诉我 cron 作业是不是运行不正常?

周期性计划任务Cron详解