ver tuberias salida historial guardar filtros demonios demonio crear contenido comandos comando archivo linux centos7 systemd rhel rhel7

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.

Fuente vía archive.org


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 o socket .

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