AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 436711
Accepted
lindhe
lindhe
Asked: 2018-04-11 00:01:13 +0800 CST2018-04-11 00:01:13 +0800 CST 2018-04-11 00:01:13 +0800 CST

为 cronjob 指定一个 systemd 单元

  • 772

当我运行一个 cronjob 时,能够跟踪它的日志真是太好了。如果我想用 来查看来自 cron 的所有日志journalctl,我可以选择cron单位 ( journalctl -u cron)。但是当我有多个 cronjobs 时,仅对 cron 单元进行过滤并不是很有帮助。

有没有办法过滤特定的 cronjob journalctl,甚至指定它应该属于的某个单元?

cron systemd-journald
  • 1 1 个回答
  • 414 Views

1 个回答

  • Voted
  1. Best Answer
    muru
    2018-04-11T01:18:31+08:002018-04-11T01:18:31+08:00

    由于这些只是来自 cron 的消息,因此元数据都是关于 cron 的。关于 cronjob 的几条消息的示例,使用--output=json:

    {
      "__CURSOR": "s=74429436aba942b6bbfc70cf45bfecc6;i=188d;b=108f80cdd87342bcb9dcafca15c45b57;m=6c13fcb19;t=5697ae32bb8a9;x=d292b55b7b7a140d",
      "__REALTIME_TIMESTAMP": "1523351401773225",
      "__MONOTONIC_TIMESTAMP": "29011987225",
      "_BOOT_ID": "108f80cdd87342bcb9dcafca15c45b57",
      "PRIORITY": "6",
      "_UID": "0",
      "_GID": "0",
      "_CAP_EFFECTIVE": "3fffffffff",
      "_MACHINE_ID": "5a75b95396344578a23193fb7b823946",
      "_HOSTNAME": "muru-1604",
      "_SYSTEMD_SLICE": "system.slice",
      "_TRANSPORT": "syslog",
      "SYSLOG_FACILITY": "10",
      "SYSLOG_IDENTIFIER": "CRON",
      "MESSAGE": "pam_unix(cron:session): session opened for user root by (uid=0)",
      "_COMM": "cron",
      "_EXE": "/usr/sbin/cron",
      "_CMDLINE": "/usr/sbin/CRON -f",
      "_AUDIT_LOGINUID": "0",
      "_SYSTEMD_CGROUP": "/system.slice/cron.service",
      "_SYSTEMD_UNIT": "cron.service",
      "SYSLOG_PID": "22158",
      "_PID": "22158",
      "_AUDIT_SESSION": "110",
      "_SOURCE_REALTIME_TIMESTAMP": "1523351401772733"
    }
    {
      "__CURSOR": "s=74429436aba942b6bbfc70cf45bfecc6;i=188e;b=108f80cdd87342bcb9dcafca15c45b57;m=6c13fcba9;t=5697ae32bb939;x=33e51a528b0cef96",
      "__REALTIME_TIMESTAMP": "1523351401773369",
      "__MONOTONIC_TIMESTAMP": "29011987369",
      "_BOOT_ID": "108f80cdd87342bcb9dcafca15c45b57",
      "PRIORITY": "6",
      "_UID": "0",
      "_GID": "0",
      "_CAP_EFFECTIVE": "3fffffffff",
      "_MACHINE_ID": "5a75b95396344578a23193fb7b823946",
      "_HOSTNAME": "muru-1604",
      "_SYSTEMD_SLICE": "system.slice",
      "_TRANSPORT": "syslog",
      "SYSLOG_IDENTIFIER": "CRON",
      "_COMM": "cron",
      "_EXE": "/usr/sbin/cron",
      "_CMDLINE": "/usr/sbin/CRON -f",
      "_AUDIT_LOGINUID": "0",
      "_SYSTEMD_CGROUP": "/system.slice/cron.service",
      "_SYSTEMD_UNIT": "cron.service",
      "SYSLOG_FACILITY": "9",
      "MESSAGE": "(root) CMD ([ -x /usr/sbin/dma ] && /usr/sbin/dma -q1)",
      "_AUDIT_SESSION": "110",
      "SYSLOG_PID": "22159",
      "_PID": "22159",
      "_SOURCE_REALTIME_TIMESTAMP": "1523351401773201"
    }
    

    这两者是相关的(例如,参见 PID 或时间戳),但这种关系不容易表示为过滤器。

    因此,没有什么journalctl可以为您做的。


    如果您使用 systemd 计时器,那么相应的单元当然可以用作过滤器journalctl(以及 systemd 计时器的所有其他好处:检查下一个运行时,立即运行作业,正确停止长时间运行的 cronjob 等。 )。

    • 1

相关问题

  • 如果 anacron 不是守护进程,它是如何工作的?

  • Cron 作业未按预期工作

  • Cron */6 小时但有偏移量?

  • 如何恢复已删除的 crontab

  • Auto-SSH 手动工作,但不在后台工作

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve