Nar*_*asK 7 systemd systemd-journald
请假设有一个应用程序/脚本可以将大量日志数据打印到stdout
. 当脚本中发生意外但预期的事情时(异常处理),脚本会向其报告错误stderr
,然后继续执行其正在执行的操作。
systemd
肯定有能力收集这些数据并将其放入journal
:
# systemctl show sd_test.service | grep 'Standard[OE]'
StandardOutput=journal
StandardError=inherit
Run Code Online (Sandbox Code Playgroud)
我的sd_test.service
:
[Unit]
Description=A Test Service simply printing to stdout and stderr
[Service]
Type=simple
ExecStart=/home/narunas/sd_test.py
[Install]
WantedBy=multi-user.target
Run Code Online (Sandbox Code Playgroud)
journalctl
现在有所需的数据:
# systemctl reenable sd_test.service
# systemctl restart sd_test.service
# journalctl -n -u sd_test
-- Logs begin at Fri 2016-11-11 15:49:33 GMT, end at Tue 2017-01-03 19:23:18 GMT. --
Jan 03 19:23:01 dev-box sd_test.py[13183]: This is "stderr": 2
Jan 03 19:23:02 dev-box sd_test.py[13183]: This is "stdout": 2
Jan 03 19:23:03 dev-box sd_test.py[13183]: This is "stderr": 3
Jan 03 19:23:07 dev-box sd_test.py[13183]: This is "stdout": 3
Jan 03 19:23:07 dev-box sd_test.py[13183]: This is "stderr": 4
Jan 03 19:23:11 dev-box sd_test.py[13183]: This is "stdout": 4
Jan 03 19:23:12 dev-box sd_test.py[13183]: This is "stderr": 5
Jan 03 19:23:15 dev-box sd_test.py[13183]: This is "stdout": 5
Jan 03 19:23:17 dev-box sd_test.py[13183]: This is "stdout": 6
Jan 03 19:23:18 dev-box sd_test.py[13183]: This is "stderr": 6
Run Code Online (Sandbox Code Playgroud)
我知道有_TRANSPORT
期刊字段,可悲的stderr
是用相同的标签标记:
标准输出
从服务的标准输出或错误输出那些读
我当然可以改变我的ExecStart
样子:
ExecStart=/bin/bash -c '/home/narunas/sd_test.py 2> /some/file/path'
Run Code Online (Sandbox Code Playgroud)
但这并不理想,因为我正在journal
与文件混在一起......
你能推荐一种更好的方法来stderr
只查看日志吗?
编辑_1
正如评论中所建议的,我刚刚尝试了-o verbose
选项:
Tue 2017-01-03 20:23:49.994171 GMT [s=0b15e5c69e2f476eb200d2bdda769465;i=12e28;b=db55b41f61144ae69cc86acfb75209fb;m=42e034d52dc;t=5453672322abb;x=8b696c5447bc2bce]
PRIORITY=6
_UID=0
_GID=0
_CAP_EFFECTIVE=3fffffffff
_SYSTEMD_SLICE=system.slice
_BOOT_ID=db55b41f61144ae69cc86acfb75209fb
_MACHINE_ID=c5a9e78e2c854065a9b041c58f07c2b2
_HOSTNAME=dev-box
SYSLOG_FACILITY=3
_TRANSPORT=stdout
SYSLOG_IDENTIFIER=sd_test.py
_COMM=python3
_EXE=/usr/bin/python3.5
_CMDLINE=python3 /home/narunas/sd_test.py
_SYSTEMD_CGROUP=/system.slice/sd_test.service
_SYSTEMD_UNIT=sd_test.service
MESSAGE=This is "stdout": 729
_PID=13183
Tue 2017-01-03 20:23:52.979981 GMT [s=0b15e5c69e2f476eb200d2bdda769465;i=12e29;b=db55b41f61144ae69cc86acfb75209fb;m=42e037ae22e;t=54536725fba0d;x=8802c0df56848907]
PRIORITY=6
_UID=0
_GID=0
_CAP_EFFECTIVE=3fffffffff
_SYSTEMD_SLICE=system.slice
_BOOT_ID=db55b41f61144ae69cc86acfb75209fb
_MACHINE_ID=c5a9e78e2c854065a9b041c58f07c2b2
_HOSTNAME=dev-box
SYSLOG_FACILITY=3
_TRANSPORT=stdout
SYSLOG_IDENTIFIER=sd_test.py
_COMM=python3
_EXE=/usr/bin/python3.5
_CMDLINE=python3 /home/narunas/sd_test.py
_SYSTEMD_CGROUP=/system.slice/sd_test.service
_SYSTEMD_UNIT=sd_test.service
MESSAGE=This is "stderr": 745
_PID=13183
Run Code Online (Sandbox Code Playgroud)
-o json-pretty
产生与 相同的结果-o verbose
,但格式不同。
除了我的脚本愚蠢的MESSAGE 之外,没有任何有用的东西可以区分什么是stderr
或stdout
。
编辑_2
与StandardError=journal
.
单位:
[Unit]
Description=A Test Service simply printing to stdout and stderr
[Service]
Type=simple
ExecStart=/home/narunas/sd_test.py
StandardError=journal
[Install]
WantedBy=multi-user.target
Run Code Online (Sandbox Code Playgroud)
日志:
# systemctl reenable sd_test.service
# systemctl restart sd_test.service
# journalctl -n -u sd_test -o verbose
Tue 2017-01-03 22:34:55.381341 GMT [s=0b15e5c69e2f476eb200d2bdda769465;i=13ab7;b=db55b41f61144ae69cc86acfb75209fb;m=42fd81d9b7e;t=545384702735d;x=e65570c85dfec1dc]
_TRANSPORT=stdout
PRIORITY=6
SYSLOG_FACILITY=3
SYSLOG_IDENTIFIER=sd_test.py
_UID=0
_GID=0
_COMM=python3
_EXE=/usr/bin/python3.5
_CMDLINE=python3 /home/narunas/sd_test.py
_CAP_EFFECTIVE=3fffffffff
_SYSTEMD_CGROUP=/system.slice/sd_test.service
_SYSTEMD_UNIT=sd_test.service
_SYSTEMD_SLICE=system.slice
_BOOT_ID=db55b41f61144ae69cc86acfb75209fb
_MACHINE_ID=c5a9e78e2c854065a9b041c58f07c2b2
_HOSTNAME=dev-box
MESSAGE=This is "stdout": 10
_PID=21280
Tue 2017-01-03 22:34:57.397880 GMT [s=0b15e5c69e2f476eb200d2bdda769465;i=13ab8;b=db55b41f61144ae69cc86acfb75209fb;m=42fd83c6099;t=5453847213878;x=610237e701d596d4]
_TRANSPORT=stdout
PRIORITY=6
SYSLOG_FACILITY=3
SYSLOG_IDENTIFIER=sd_test.py
_UID=0
_GID=0
_COMM=python3
_EXE=/usr/bin/python3.5
_CMDLINE=python3 /home/narunas/sd_test.py
_CAP_EFFECTIVE=3fffffffff
_SYSTEMD_CGROUP=/system.slice/sd_test.service
_SYSTEMD_UNIT=sd_test.service
_SYSTEMD_SLICE=system.slice
_BOOT_ID=db55b41f61144ae69cc86acfb75209fb
_MACHINE_ID=c5a9e78e2c854065a9b041c58f07c2b2
_HOSTNAME=dev-box
MESSAGE=This is "stderr": 11
_PID=21280
Tue 2017-01-03 22:35:02.403014 GMT [s=0b15e5c69e2f476eb200d2bdda769465;i=13abc;b=db55b41f61144ae69cc86acfb75209fb;m=42fd888bfe7;t=54538476d97c6;x=a6362820cb52ce9]
_TRANSPORT=stdout
PRIORITY=6
SYSLOG_FACILITY=3
SYSLOG_IDENTIFIER=sd_test.py
_UID=0
_GID=0
_COMM=python3
_EXE=/usr/bin/python3.5
_CMDLINE=python3 /home/narunas/sd_test.py
_CAP_EFFECTIVE=3fffffffff
_SYSTEMD_CGROUP=/system.slice/sd_test.service
_SYSTEMD_UNIT=sd_test.service
_SYSTEMD_SLICE=system.slice
_BOOT_ID=db55b41f61144ae69cc86acfb75209fb
_MACHINE_ID=c5a9e78e2c854065a9b041c58f07c2b2
_HOSTNAME=dev-box
MESSAGE=This is "stderr": 12
_PID=21280
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6855 次 |
最近记录: |