salida - tuberias y filtros en linux
Cómo redirigir la salida del servicio systemd a un archivo (6)
Estoy tratando de redirigir la salida de un servicio
systemd
a un archivo, pero parece que no funciona:
[Unit]
Description=customprocess
After=network.target
[Service]
Type=forking
ExecStart=/usr/local/bin/binary1 agent -config-dir /etc/sample.d/server
StandardOutput=/var/log1.log
StandardError=/var/log2.log
Restart=always
[Install]
WantedBy=multi-user.target
Por favor corrige mi enfoque.
Creo que hay una forma más elegante de resolver el problema: envíe stdout / stderr a syslog con un identificador e indique a su administrador de syslog que divida su salida por nombre de programa.
Utilice las siguientes propiedades en su archivo de unidad de servicio systemd:
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=<your program identifier> # without any quote
Luego, suponiendo que su distribución esté usando rsyslog para administrar syslogs, cree un archivo en
/etc/rsyslog.d/<new_file>.conf
con el siguiente contenido:
if $programname == ''<your program identifier>'' then /path/to/log/file.log
& stop
Ahora haga que el archivo de registro sea editable por syslog:
# ls -alth /var/log/syslog
-rw-r----- 1 syslog adm 439K Mar 5 19:35 /var/log/syslog
# chown syslog:adm /path/to/log/file.log
Reinicie rsyslog (
sudo systemctl restart rsyslog
) y ¡disfrute!
Su programa stdout / stderr todavía estará disponible a través de journalctl (
sudo journalctl -u <your program identifier>
) pero también estarán disponibles en su archivo de elección.
Posiblemente reciba este error:
Failed to parse output specifier, ignoring: /var/log1.log
Desde la
systemd.exec(5)
del
systemd.exec(5)
man
systemd.exec(5)
:
StandardOutput=
Controla dónde está conectado el descriptor de archivo 1 (STDOUT) de los procesos ejecutados. Toma uno de
inherit
,null
,tty
,journal
,syslog
,kmsg
,journal+console
,syslog+console
,kmsg+console
osocket
.
La página del
systemd.exec(5)
man
systemd.exec(5)
explica otras opciones relacionadas con el registro.
Consulte también las
systemd.service(5)
y
systemd.unit(5)
.
O tal vez puedes probar cosas como esta (todo en una línea):
ExecStart=/bin/sh -c ''/usr/local/bin/binary1 agent -config-dir /etc/sample.d/server 2>&1 > /var/log.log''
Si por alguna razón no puede usar rsyslog, esto hará:
ExecStart=/bin/bash -ce "exec /usr/local/bin/binary1 agent -config-dir /etc/sample.d/server >> /var/log/agent.log 2>&1"
Si tiene una distribución más nueva con un
systemd
más reciente (
systemd
versión 236 o más reciente
), puede establecer los valores de
StandardOutput
o
StandardError
para
file:YOUR_ABSPATH_FILENAME
.
Larga historia:
En las versiones más recientes de
systemd
hay una opción relativamente nueva (
la solicitud de github es de 2016 ish y la mejora se fusionó / cerró 2017 ish
) donde puede establecer los valores de
StandardOutput
o
StandardError
para
file:YOUR_ABSPATH_FILENAME
.
La opción
file:path
está documentada en la
página de manual
systemd.exec
más reciente
.
Esta nueva característica es relativamente nueva y, por lo tanto, no está disponible para distribuciones anteriores como centos-7 (o cualquier centos anterior).
Sugeriría agregar el archivo
stdout
y
stderr
en el archivo de
service
systemd mismo.
En referencia: https://www.freedesktop.org/software/systemd/man/systemd.exec.html#StandardOutput=
Como lo ha configurado, no debería gustarle:
StandardOutput=/home/user/log1.log
StandardError=/home/user/log2.log
Debería ser:
StandardOutput=file:/home/user/log1.log
StandardError=file:/home/user/log2.log
Esto funciona cuando no desea reiniciar el servicio una y otra vez .
Esto creará un nuevo archivo y no se agregará al archivo existente.
Use en su lugar:
StandardOutput=append:/home/user/log1.log
StandardError=append:/home/user/log2.log
NOTA: Asegúrese de crear el directorio ya. Supongo que no es compatible para crear un directorio.
Suponga que los registros ya están en
stdout / stderr
, y tienen el inicio de sesión de la unidad systemd
/var/log/syslog
journalctl -u unitxxx.service
Jun 30 13:51:46 host unitxxx[1437]: time="2018-06-30T11:51:46Z" level=info msg="127.0.0.1
Jun 30 15:02:15 host unitxxx[1437]: time="2018-06-30T13:02:15Z" level=info msg="127.0.0.1
Jun 30 15:33:02 host unitxxx[1437]: time="2018-06-30T13:33:02Z" level=info msg="127.0.0.1
Jun 30 15:56:31 host unitxxx[1437]: time="2018-06-30T13:56:31Z" level=info msg="127.0.0.1
Config rsyslog (Servicio de registro del sistema)
# Create directory for log file
mkdir /var/log/unitxxx
# Then add config file /etc/rsyslog.d/unitxxx.conf
if $programname == ''unitxxx'' then /var/log/unitxxx/unitxxx.log
& stop
Reiniciar rsyslog
systemctl restart rsyslog.service