web-dev-qa-db-ja.com

systemctlを同期的に開始させる方法はありますか

Systemdのユニットファイルを開発中/開発済み

[Unit]
Description=FreeRADIUS multi-protocol policy server
After=syslog.target network.target
Documentation=man:radiusd(8) man:radiusd.conf(5) http://wiki.freeradius.org/ http://networkradius.com/doc/

[Service]
EnvironmentFile=-/etc/sysconfig/radiusd
ExecStartPre=/usr/sbin/radiusd $FREERADIUS_OPTIONS -Cxm -lstdout
ExecStart=/usr/sbin/radiusd $FREERADIUS_OPTIONS -fm
Restart=on-abnormal

[Install]
WantedBy=multi-user.target

systemctl radiusd startがエラーコードで終了しても、/usr/sbin/radiusd -fmを呼び出してもエラーコードが返されないという問題が発生しています。

Systemctlを同期的に動作させる方法はありますか?つまり、戻る前に設定された期間待機し、サービスが正常に/失敗して開始されたことを示します。

Type=forkingまたはdbusなどの他のオプションに変更しても問題ありません(そしてdbusと統合するコードを記述します)。

明らかな質問を先取りするために、はい、開始後、systemdはユニットが失敗したと見なします。

bash-4.2# systemctl status radiusd
radiusd.service - FreeRADIUS multi-protocol policy server
   Loaded: loaded (/usr/lib/systemd/system/radiusd.service; enabled)
   Active: failed (Result: start-limit) since Wed 2015-08-12 12:26:18 EDT; 19s ago
     Docs: man:radiusd(8)
           man:radiusd.conf(5)
           http://wiki.freeradius.org/
           http://networkradius.com/doc/
  Process: 10610 ExecStart=/usr/sbin/radiusd $FREERADIUS_OPTIONS -fm (code=exited, status=1/FAILURE)
 Main PID: 10610 (code=exited, status=1/FAILURE)

はい、systemctl status radiusdは0以外の終了コードを返します。これをソルトスタックと統合するのは面倒です。現在、同期開始がない場合、バンドルされたsaltstack pkgモジュールは、サービスの失敗の原因となる構成/コードの更新を適用した後、サービスが実行中であると報告します。

1

あなたはすでにあなた自身の質問に答えていると思います。

デーモンをフォークし、systemctlがステータスコードを返すようにしたい場合は、Type=forkingが最適です。 Type=oneshotもあります。これは、デーモンとして実行するのではなく、スクリプト/プログラムが終了することが予想される場合にのみ使用してください。 systemctlは、実際にはExecStart=プログラムが終了するのを待ちます。

私のCentOS7.1マシンから:

[unixguy@infra01 system]$ pwd
/usr/lib/systemd/system
[unixguy@infra01 system]$ find ./ -type f | xargs grep 'Type='  | awk -F: '{print $2}' | sort | uniq -c | sort -nr | head -5
     64 Type=oneshot
     37 Type=forking
     11 Type=notify
      6 Type=idle
      6 Type=dbus
[unixguy@infra01 system]$ find ./ -type f | xargs grep 'Type=forking' | awk -F: '{print $1}' | head
./rc-local.service
./rdisc.service
./tcsd.service
./plymouth-kexec.service
./plymouth-halt.service
./plymouth-poweroff.service
./plymouth-reboot.service
./plymouth-start.service
./rpc-statd.service
./systemd-cfengine-bootstrap.service
[unixguy@infra01 system]$ find ./ -type f | xargs grep 'Type=oneshot' | awk -F: '{print $1}' | head
./systemd-kexec.service
./quotaon.service
./halt-local.service
./initrd-cleanup.service
./initrd-parse-etc.service
./initrd-switch-root.service
./initrd-udevadm-cleanup-db.service
./kmod-static-nodes.service
./systemd-binfmt.service
./[email protected]

ご覧のとおり、デーモンサービスはType=forkingを使用しており、1回限りの実行サービス/スクリプトはType=oneshotを使用しています。

2
Soumyadip DM