Auf RHEL7.5 laufender Dienst läuft nicht auf RHEL8 (httpd-Dienst)

Auf RHEL7.5 laufender Dienst läuft nicht auf RHEL8 (httpd-Dienst)

Ich habe einen Dienst, der mit RHEL 7.5 einwandfrei funktionierte. Jetzt habe ich ein Upgrade auf RHEL 8 durchgeführt und derselbe Dienst schlägt mit dem folgenden Status fehl:

Service.service - LSB: Web Server
Loaded: loaded (/etc/rc.d/init.d/Service; generated)
Active: failed (Result: protocol) since Mon 2020-04-06 12:02:21 IST; 38min ago
Docs: man:systemd-sysv-generator(8)
Process: 403 ExecStart=/etc/rc.d/init.d/Service start (code=exited, status=0/SUCCESS)

Apr 06 12:02:21 localhost.localdomain systemd[1]: Starting LSB: Web Server...
Apr 06 12:02:21 localhost.localdomain Service[403]: httpd (pid 29434) already running
Apr 06 12:02:21 localhost.localdomain systemd[1]: Service.service: Refusing to accept PID outside of service control group, acquired through unsafe symlink chain:
/usr/local/apache/logs/Service.pid
Apr 06 12:02:21 localhost.localdomain systemd[1]: Service.service: Refusing to accept PID outside of service control group, acquired through unsafe symlink chain:
/usr/local/apache/logs/Service.pid
Apr 06 12:02:21 localhost.localdomain systemd[1]: Service.service: Failed with result 'protocol'.
Apr 06 12:02:21 localhost.localdomain systemd[1]: Failed to start LSB: Web Server

Dies ist meine Service-Einheit, die unter /etc/init.d/Service abgelegt ist. Dasselbe gilt für RHEL 7.5, aber dort funktioniert dieser Service und in RHEL 8 nicht. Eine weitere Anmerkung ist, dass der Webserver wie erwartet funktioniert, obwohl er mir diesen Fehler anzeigt.

    #!/bin/sh
#
# chkconfig: 345 97 03
# description:Web Server
# processname: httpd
# config: /usr/local/Test/apache/conf/httpd.conf
# pidfile: /usr/local/Test/apache/logs/httpd.pid

### BEGIN INIT INFO
# Provides: Service
# Required-Start: $remote_fs $network $syslog
# Should-Start:
# Required-Stop:
# Default-Start: 3 4 5
# Default-Stop: 0 1 2 6`enter code here`
# Short-Description: Web Server
# Description: Web Server
### END INIT INFO

LANG=en_US.iso88591
export LANG

BASEDIR=/usr/local/Test/apache
PATH=$BASEDIR/bin:/usr/bin:/bin
export PATH

LD_LIBRARY_PATH=$BASEDIR/lib
export LD_LIBRARY_PATH

inst=/usr/local/Test
MIBDIRS=$inst/mibs
export MIBDIRS

case $1 in
start)
  apachectl start
  ;;
stop)
  apachectl stop
  ;;
restart)
  apachectl restart
  ;;
*)
  echo "usage: $0 { start | stop | restart }"
  ;;
esac

Bitte helfen Sie mir dabei.

Antwort1

Wenn Sie im Journaleintrag sehen:

Refusing to accept PID outside of service control group, acquired through unsafe symlink chain:

Die Version von systemd in 7.5 verfügt nicht über die zusätzlichen Prüfungen, um zu ermitteln, ob sich die PID für den Dienst außerhalb der Kontrollgruppe der systemd-Einheit befindet.

Wenn Sie das 7.5-System auf 7.7 oder höher aktualisieren würden, würde dies ebenfalls mit dem gleichen Fehler fehlschlagen.

Möglicherweise haben Sie mehr Glück, wenn Sie das Sysv-Init-Skript in eine echte Systemd-Serviceeinheit konvertieren.

verwandte Informationen