public inbox for development@lists.ipfire.org
 help / color / mirror / Atom feed
From: Michael Tremer <michael.tremer@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH] squid init v_final
Date: Wed, 18 May 2016 19:15:46 +0100	[thread overview]
Message-ID: <1463595346.19435.15.camel@ipfire.org> (raw)
In-Reply-To: <1463513604-30805-1-git-send-email-matthias.fischer@ipfire.org>

[-- Attachment #1: Type: text/plain, Size: 5412 bytes --]

Hi,

thanks. I finally merged this with a few changes:

  http://git.ipfire.org/?p=ipfire-2.x.git;a=commitdiff;h=6113575d81201591b2e8a76520579a4e7b7c5d46

and added some more changes:

  http://git.ipfire.org/?p=ipfire-2.x.git;a=commitdiff;h=691b2836c0ffa54b3f7fc8d6f3b98377b3c9a470
  http://git.ipfire.org/?p=ipfire-2.x.git;a=commitdiff;h=3fcc9b67fc7ab1886244a647dd7cf98f00e5c555

I used boot_mesg instead of echo in some situations. Refrased the warning
message. Removed -r from rm. And finally if squid shut down gracefully the shut
down time is logged to syslog instead of being written to the console.

I also added some more comments to the script so that we know what is going on
in a few months down from here.

This is working fine for me. Even with a small and almost empty cache squid
takes about 14 seconds to shut down on my IPFire Prime Box.

Please test everything again. I am going to deploy this on a few more test
systems this week.

Best,
-Michael

On Tue, 2016-05-17 at 21:33 +0200, Matthias Fischer wrote:
> Last update suggestions for (3.5.xx) initscript, awaiting feedback. ;-)
> 
> Changelog:
> 
> - Raised 'while'-loop-time for stopping squid to 360 seconds until
>   '/var/log/cache/swap.state' is deleted. NOT the whole cache structure!
>   I know, this timeout could not be enough for really BIG caches.
>   The only other choice I know would be to leave this loop alone without
>   the "xxx seconds"-counter and wait how 'squid -k shutdown' handles this.
>   But if it fails, I fear that we could end up in an endless loop.
>   Suggestions are welcome!
> 
> - Had to delete 'wait' after killing squidguard, updxlrator, squidclamav
>   and redirect_wrappers - 'while'-loop counter wouldn't work because of
>   this line.
>   Suggestions for better handling?
> 
> - Process detection looks for leftover '(squid-1)'-process using 'pgrep'.
> 
> - Cosmetic changes to some 'boot_mesg' lines. Added a few. Is it
>   (still) too much? I'd prefer to get a warning (an announcement) if
>   '/var/log/cache/swap.state' was deleted.
> 
> - Changed the 'flush'-command to really delete the entire
>   '/var/log/cache'-structure, it will automatically be rebuild
>   during the next start.
>   Reason: a CLEAR cache command should really CLEAR the cache!
> 
> Best,
> Matthias
> 
> Signed-off-by: Matthias Fischer <matthias.fischer(a)ipfire.org>
> ---
>  src/initscripts/init.d/squid | 55 ++++++++++++++++++++++++++++---------------
> -
>  1 file changed, 35 insertions(+), 20 deletions(-)
> 
> diff --git a/src/initscripts/init.d/squid b/src/initscripts/init.d/squid
> index abed90a..1b369ea 100644
> --- a/src/initscripts/init.d/squid
> +++ b/src/initscripts/init.d/squid
> @@ -94,9 +94,9 @@ case "$1" in
>  	stop)
>  			iptables -t nat -F SQUID
>  		if [ -e /var/run/squid.pid ]; then
> -			boot_mesg "Stopping Squid Proxy Server..."
> -			squid -k shutdown >/dev/null 2>&1
> -			evaluate_retval
> +			boot_mesg -n "Stopping Squid Proxy Server...\n"
> +			boot_mesg "(this may take up to a few minutes)"
> +			/usr/sbin/squid -k shutdown >/dev/null 2>&1
>  
>  			# Stop squidGuard, updxlrator, squidclamav
>  			# and redirect_wrappers.
> @@ -105,25 +105,41 @@ case "$1" in
>  			killproc /usr/bin/squidclamav >/dev/null &
>  			killproc /usr/sbin/redirect_wrapper >/dev/null &
>  
> -			# Wait until all redirectors have been stopped.
> -			wait
> -
> -			# If squid is still running, wait up to 30 seconds
> -			# before we go on to kill it.
> -			counter=30
> -
> -			while [ ${counter} -gt 0 ]; do
> -				statusproc /usr/sbin/squid >/dev/null &&
> break;
> -				sleep 1
> -				counter=$(( ${counter} - 1))
> +			# If some squid processes are still running, wait up
> to 360 seconds
> +			# before we go on to kill the remaining process(es)
> and delete damaged
> +			# '/var/log/cache/swap.state'.
> +			n=0
> +			while squid -k check > /dev/null 2>&1 && [ $n -lt 360
> ]; do
> +				sleep 2
> +				n=$(( ${n} + 2 ))
> +				echo -n .
>  			done
> -
> -			# Kill squid service, if still running.
> -			killproc /usr/sbin/squid >/dev/null
> +			echo ""
> +			echo "Done."
> +			echo "Shutdown time:" "$n" "seconds"
> +
> +			# If (squid-1) is still running after 360 seconds,
> +			# kill all squid processes and delete
> '/var/log/cache/swap.state'.
> +			if ( pgrep -fl "(squid-1)" > /dev/null 2>&1 ); then
> +				killproc /usr/sbin/squid >/dev/null
> +				rm -rf /var/log/cache/swap.state
> +				echo ""
> +				boot_mesg -n "You should not be reading this
> warning.\n"
> +				boot_mesg -n "Some squid-processes had to be
> killed after 360 seconds,\n"
> +				boot_mesg -n "so the cache index file was
> damaged and had to be deleted.\n"
> +				boot_mesg -n "This file will be rebuild
> during the next start."
> +				echo_warning
> +				echo ""
> +			else
> +				boot_mesg "All squid processes exited
> normally."
> +				echo_ok
> +				echo ""
> +			fi
> +		fi
>  
>  			# Trash remain pid file from squid.
>  			rm -rf /var/run/squid.pid
> -		fi
> +
>  		;;
>  
>  	restart)
> @@ -143,8 +159,7 @@ case "$1" in
>  
>  	flush)
>  		$0 stop
> -		echo > /var/log/cache/swap.state
> -		chown squid.squid /var/log/cache/swap.state
> +		rm -rf /var/log/cache/*
>  		sleep 1
>  		$0 start
>  		;;

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 819 bytes --]

  reply	other threads:[~2016-05-18 18:15 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-05-17 19:33 Matthias Fischer
2016-05-18 18:15 ` Michael Tremer [this message]
2016-05-18 19:03   ` Matthias Fischer
2016-05-18 21:22     ` Michael Tremer
2016-05-19 19:03       ` Matthias Fischer
2016-05-20 10:06         ` Michael Tremer

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=1463595346.19435.15.camel@ipfire.org \
    --to=michael.tremer@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