Comment rediriger la sortie du service systemd vers un fichier

j'essaie de rediriger o/p d'un service systemd vers un fichier mais cela ne semble pas fonctionner. Je le fais comme suit:

[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

s'il vous Plaît suggérer la bonne approche pour rediriger o/p pour un fichier

66
demandé sur Mark Stosberg 2016-06-02 10:51:46

5 réponses

je pense qu'il y a une façon plus élégante de résoudre le problème: envoyer le stdout/stderr à syslog avec un identifiant et demander à votre gestionnaire syslog de diviser sa sortie par programname.

utilisez les propriétés suivantes dans votre fichier Unité de service systemd:

StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=<your program identifier> # without any quote

ensuite, en supposant que votre distribution utilise rsyslog pour gérer les syslogs, créez un fichier dans /etc/rsyslog.d/<new_file>.conf avec le contenu suivant:

if $programname == '<your program identifier>' then /path/to/log/file.log
& stop

redémarrez rsyslog (sudo systemctl redémarrez rsyslog) et profitez! Votre programme stdout / stderr sera toujours disponible via journalctl (sudo journalctl-u ) mais ils seront également disponibles dans le fichier de votre choix.

Source: http://wiki.rsyslog.com/index.php/Filtering_by_program_name

115
répondu Valerio Versace 2018-07-30 16:19:03

vous avez probablement cette erreur:

Failed to parse output specifier, ignoring: /var/log1.log

De la systemd.exec(5) l'homme page:

StandardOutput=

contrôle où le descripteur de fichier 1 (STDOUT) des processus exécutés est connecté. Prend un de inherit , null , tty , journal , syslog , kmsg , journal+console , syslog+console , kmsg+console ou socket .

la page de manuel systemd.exec(5) explique d'autres options liées à la journalisation. Voir aussi les pages de manuel systemd.service(5) et systemd.unit(5) .

ou peut-être vous pouvez essayer des choses comme ceci (tous sur une ligne):

ExecStart=/bin/sh -c '/usr/local/bin/binary1 agent -config-dir /etc/sample.d/server 2>&1 > /var/log.log' 
29
répondu Shuangistan 2017-07-13 10:49:55

si vous avez une nouvelle distro avec une nouvelle systemd ( systemd version 236 ou plus récente ), vous pouvez définir les valeurs de StandardOutput ou StandardError à file:YOUR_ABSPATH_FILENAME .


longue histoire:

dans les nouvelles versions de systemd Il ya une option relativement nouvelle ( la demande github est à partir de 2016 ish et l'amélioration est fusionné/fermé 2017 ish ) où vous pouvez définir les valeurs de StandardOutput ou StandardError à file:YOUR_ABSPATH_FILENAME . L'option file:path est documentée dans la la plus récente systemd.exec man page .

cette nouvelle caractéristique est relativement nouvelle et n'est donc pas disponible pour les distros plus anciennes comme centos-7 (ou n'importe quel centos avant cela).

20
répondu Trevor Boyd Smith 2018-01-01 19:04:04

si, pour une raison quelconque, vous ne pouvez pas utiliser rsyslog, cela fera: ExecStart=/bin/bash -ce "exec /usr/local/bin/binary1 agent -config-dir /etc/sample.d/server >> /var/log/agent.log 2>&1"

9
répondu Tigra 2017-09-11 20:44:31

supposons que les logs sont déjà mis à stdout/stderr , et ont le log de l'unité systemd dans /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 (Système de Service de Journalisation)

# 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

Redémarrer rsyslog

systemctl restart rsyslog.service
1
répondu Hieu Huynh 2018-06-30 16:21:39