From: Adolf Belka <adolf.belka@ipfire.org>
To: development@lists.ipfire.org
Subject: [PATCH] apache: Fixes bug13656 - Add delay between stop & start of restart command.
Date: Wed, 24 Apr 2024 17:56:51 +0200 [thread overview]
Message-ID: <20240424155651.3426712-1-adolf.belka@ipfire.org> (raw)
[-- Attachment #1: Type: text/plain, Size: 2389 bytes --]
- The change of the apache initscript in CU181 made the restart comand a stop followed by a
start. From bug13656 it looks like when the start is run the pid file may not yet be
fully removed and so apache is not started, although the pid is being removed.
- This patch checks if the pid file is still present every second up to 10 seconds. Once the
pid file is gone then the stop command is completed and the initscript moves to the start
command.
- Rather than apply a fixed delay of 2 or 3 or 4 seconds I used a while loop to check every
second if the file is still present. If at the end of 10 seconds it is still present
then something went wrong with the pid removal.
- I have tested this patch on my vm system and it worked but it would be good to be
reviewed to make sure that it is a reasonable approach that has been used and if required
changed in whatever way makes the best sense.
Fixes: Bug13656
Tested-by: Adolf Belka <adolf.belka(a)ipfire.org>
Signed-off-by: Adolf Belka <adolf.belka(a)ipfire.org>
---
src/initscripts/system/apache | 12 +++++++++++-
1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/src/initscripts/system/apache b/src/initscripts/system/apache
index 18eb86e2f..087e4084e 100644
--- a/src/initscripts/system/apache
+++ b/src/initscripts/system/apache
@@ -2,7 +2,7 @@
###############################################################################
# #
# IPFire.org - A linux based firewall #
-# Copyright (C) 2007-2022 IPFire Team <info(a)ipfire.org> #
+# Copyright (C) 2007-2024 IPFire Team <info(a)ipfire.org> #
# #
# This program is free software: you can redistribute it and/or modify #
# it under the terms of the GNU General Public License as published by #
@@ -87,6 +87,16 @@ case "$1" in
stop)
boot_mesg "Stopping Apache daemon..."
/usr/sbin/apachectl -k stop
+ COUNTER=0
+ while [ -e /var/run/httpd.pid ]
+ do
+ sleep 1
+ (( COUNTER++ ))
+ if [ $COUNTER -eq 10 ]; then
+ boot_mesg "pid not removed after 10 seconds"
+ break
+ fi
+ done
evaluate_retval
;;
--
2.44.0
next reply other threads:[~2024-04-24 15:56 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-04-24 15:56 Adolf Belka [this message]
2024-04-26 14:45 ` Michael Tremer
2024-04-26 15:08 ` Adolf Belka
2024-04-26 15:30 ` Michael Tremer
2024-04-26 17:08 ` Adolf Belka
2024-04-29 19:44 ` Adolf Belka
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20240424155651.3426712-1-adolf.belka@ipfire.org \
--to=adolf.belka@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox