そのため、システムサポートシステムでサービスを開始しようとしています。サービス名は、ossec-hids-authd
ossec(侵入検知ソフトウェア)の認証エンジン(プロキシ)です。 initスクリプトを起動すると、systemctlがタイムアウトし、ステータスの取得中にこのエラーが表示されます。
/etc/init.d/ossec-hids-authd status
● ossec-hids-authd.service - LSB: Authentication Daemon for OSSEC-HIDS.
Loaded: loaded (/etc/rc.d/init.d/ossec-hids-authd; bad; vendor preset: disabled)
Active: failed (Result: timeout) since Thu 2018-02-22 07:34:28 UTC; 11min ago
Docs: man:systemd-sysv-generator(8)
Feb 22 07:24:11 ip-10-0-197-117.ec2.internal systemd[1]: Starting LSB: Authentication Daemon for OSSEC-HIDS....
Feb 22 07:24:11 ip-10-0-197-117.ec2.internal ossec-hids-authd[21142]: [39B blob data]
Feb 22 07:24:11 ip-10-0-197-117.ec2.internal systemd[1]: PID file /var/run/ossec-authd.pid not readable (yet?) after start.
Feb 22 07:24:11 ip-10-0-197-117.ec2.internal ossec-hids-authd[21142]: 2018/02/22 07:24:11 ossec-authd: INFO: Started (pid: 21148).
Feb 22 07:34:28 ip-10-0-197-117.ec2.internal systemd[1]: ossec-hids-authd.service start operation timed out. Terminating.
Feb 22 07:34:28 ip-10-0-197-117.ec2.internal systemd[1]: Failed to start LSB: Authentication Daemon for OSSEC-HIDS..
Feb 22 07:34:28 ip-10-0-197-117.ec2.internal systemd[1]: Unit ossec-hids-authd.service entered failed state.
Feb 22 07:34:28 ip-10-0-197-117.ec2.internal systemd[1]: ossec-hids-authd.service failed.
Feb 22 07:40:20 ip-10-0-197-117.ec2.internal ossec-hids-authd[21142]: 2018/02/22 07:40:20 ossec-authd(1225): INFO: SIGNAL [(15)-(Terminated)] Received. Exit Cleaning...
initスクリプトでは、プロセスが実際にpidファイルを生成するの/var/ossec/var/run
ではなく、/var/run
pidファイルが実際に作成されていることを確認しました。しかし、どういうわけかsystemctlはそれを認識しません。
systemdが外部で生成されたpidファイルを認識しない可能性はありますか/var/run
?この場合、どうすればよいですか?
以下は初期化スクリプトです。
#!/bin/sh
#
# ossec-authd Start the OSSEC-HIDS Authentication Daemon
#
# chkconfig: 2345 99 01
# description: Provides key signing for OSSEC Clients
# processname: ossec-authd
# config: /var/ossec/etc/ossec.conf
# pidfile: /var/run/ossec-authd.pid
### BEGIN INIT INFO
# Provides: ossec-authd
# Required-Start: $network $local_fs $remote_fs
# Required-Stop: $network $local_fs $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Authentication Daemon for OSSEC-HIDS.
# Description: Provides key signing for OSSEC Clients
### END INIT INFO
# Author: Brad Lhotsky <[email protected]>
NAME=ossec-authd
DAEMON=/var/ossec/bin/ossec-authd
DAEMON_ARGS="-p 1515 2>&1 >> /var/ossec/logs/ossec-authd.log &"
PIDDIR=/var/ossec/var/run
SCRIPTNAME=/etc/init.d/ossec-authd
. /etc/rc.d/init.d/functions
getpid() {
for filename in $PIDDIR/${NAME}*.pid; do
pidfile=$(basename $filename)
pid=$(echo $pidfile |cut -d\- -f 3 |cut -d\. -f 1)
kill -0 $pid &> /dev/null
RETVAL=$?
if [ $RETVAL -eq 0 ]; then
PIDFILE=$filename
PID=$pid
else
rm -f $filename
fi;
done;
}
start() {
echo -n $"Starting $NAME: "
daemon $DAEMON $DAEMON_ARGS
retval=$?
if [ $retval -eq 0 ]; then
echo_success
echo
else
echo_failure
echo
fi
return $retval
}
stop() {
echo -n $"Stopping $NAME: "
getpid
killproc -p $PIDFILE $NAME
retval=$?
echo
return $retval
}
restart() {
stop
start
}
case "$1" in
start)
start
;;
stop)
stop
;;
status)
getpid
if [ -z $PIDFILE ]; then
status $NAME
else
status -p $PIDFILE $NAME
fi;
;;
restart)
restart
;;
*)
echo "Usage: $0 {start|stop|status}"
exit 2
;;
esac
exit $?
答え1
systemdは、起動時またはコマンド時にdaemon-reload
一時的な.serviceファイルを生成するためにinitスクリプトのコメントを解析します。改行
# pidfile: /var/run/ossec-authd.pid
到着
# pidfile: /var/ossec/var/run/ossec-authd.pid
そして走るsystemctl daemon-reload
UPD:実行時にauthdによってpidファイル名が生成され、initスクリプトが$ PIDDIR / $ {NAME} * .pidを検索する必要があることがわかります。
Systemdはpidfileを取得できませんが、pidfileがなくても機能します。したがって、# pidfile:
行を完全に削除したり、独自の.serviceファイルを作成したりできます。
答え2
これらすべては完全に不要です。
systemd-sysv-generator
以前のRedHatアノテーションヘッダとLSBヘッダを使用したvan Smoorenburgスクリプトの動作はrc
興味深いが無意味な時間の無駄です。
rc
van Smoorenburgスクリプトを変更し、PIDファイルが正しく機能するのに時間を無駄にしないでください。適切なサービス管理を使用すると、実際には不安定で危険なPIDファイルメカニズムは必要ありません。あなたはそのような人になる必要はありませんossec-control
。そのすべてを忘れて自分自身を体系化されたサービス単位にしてください。
オプションが必要かどうかに応じて、2つの異なるクラスのOSSECサービスの2つの単純なテンプレートサービスユニットが、ここに追加の-f
読み取り項目としてリストされている答えに記載されています。一方または両方を調整します。