web-dev-qa-db-fra.com

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 vers un fichier

85
meallhour

Je pense qu'il existe un moyen plus élégant de résoudre le problème: envoyez stdout/stderr à syslog avec un identifiant et demandez à votre gestionnaire de syslog de scinder sa sortie par nom de programme.

Utilisez les propriétés suivantes dans votre fichier d'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 restart rsyslog) et profitez-en! Votre programme stdout/stderr sera toujours disponible via journalctl (Sudo journalctl -u <your program identifier>) mais ils seront également disponibles dans le fichier de votre choix.

Source: http://wiki.rsyslog.com/index.php/Filtering_by_program_name (lien brisé, archive disponible sur Archive.org )

139
Valerio Versace

Vous avez peut-être cette erreur:

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

Depuis la page de manuel systemd.exec(5)

StandardOutput=

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

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

Ou peut-être que vous pouvez essayer des choses comme celle-ci (sur une seule ligne):

ExecStart=/bin/sh -c '/usr/local/bin/binary1 agent -config-dir /etc/sample.d/server 2>&1 > /var/log.log' 
34
Shuangistan

Si vous avez une distribution plus récente avec une version plus récente 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 versions plus récentes de systemd, il existe une option relativement nouvelle ( la demande github date de 2016 ish et l'amélioration est fusionnée/fermée 2017 ish ), dans laquelle vous pouvez définir les valeurs de StandardOutput ou StandardError à file:YOUR_ABSPATH_FILENAME. L'option file:path est documentée dans la page de manuel le plus récent systemd.exec .

Cette nouvelle fonctionnalité est relativement nouvelle et n’est donc pas disponible pour les anciennes distributions telles que centos-7 (ou toutes les centos précédentes).

29
Trevor Boyd Smith

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

11
Tigra

Suppose que les journaux sont déjà placés dans stdout/stderr , et que le journal de l'unité systemd est /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 (service de journalisation système)

# 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émarrez rsyslog

systemctl restart rsyslog.service
0
Hieu Huynh

Je suggérerais d’ajouter le fichier stdout et stderr au fichier systemd service.

Comme vous l'avez configuré, il ne devrait pas ressembler à: 

StandardOutput=/var/log1.log
StandardError=/var/log2.log

CA devrait etre: 

StandardOutput=file:/var/log1.log
StandardError=file:/var/log2.log

Assurez-vous de créer le répertoire déjà. Je suppose que cela ne supporte pas la création de répertoire.

0
Rajat jain