Sur ma machine Ubuntu, j'ai squid en tant que démon qui commence au démarrage.
Le problème est que squid met longtemps à démarrer et s’arrêter (plus de 30 secondes) et qu’il a également considérablement ralenti le temps de démarrage/arrêt de mon système d’exploitation.
Comment puis-je résoudre ce problème?
Il existe un paramètre appelé shutdown_lifetime. Il a une valeur par défaut de 30 secondes.
Ainsi, lorsque Squid reçoit une demande d'arrêt, il attend au moins 30 secondes avant de se terminer.
$ grep -B 8 "# shutdown_lifetime" /etc/squid3/squid.conf
# TAG: shutdown_lifetime time-units
# When SIGTERM or SIGHUP is received, the cache is put into
# "shutdown pending" mode until all active sockets are closed.
# This value is the lifetime to set for all open descriptors
# during shutdown mode. Any active clients after this many
# seconds will receive a 'timeout' message.
# Default:
# shutdown_lifetime 30 seconds
Décommentez simplement la dernière ligne et définissez un délai plus court:
shutdown_lifetime 10 seconds
Pour plus d'informations, voir ci-dessous.
J'ai trouvé ceci pour le paquet Squid 3.1.20-2.2 pour Debian Wheezy.
$ vim /etc/init.d/squid3
...
78
79 stop () {
80 PID=`cat $PIDFILE 2>/dev/null`
81 start-stop-daemon --stop --quiet --pidfile $PIDFILE --exec $DAEMON
82 #
83 # Now we have to wait until squid has _really_ stopped.
84 #
85 sleep 2
86 if test -n "$PID" && kill -0 $PID 2>/dev/null
87 then
88 log_action_begin_msg " Waiting"
89 cnt=0
90 while kill -0 $PID 2>/dev/null
91 do
92 cnt=`expr $cnt + 1`
93 if [ $cnt -gt 24 ]
94 then
95 log_action_end_msg 1
96 return 1
97 fi
98 sleep 5
99 log_action_cont_msg ""
100 done
101 log_action_end_msg 0
102 return 0
103 else
104 return 0
105 fi
106 }
107...
, cette fonction utilise ce signal non reconnu (0).
Solution de contournement: à la ligne 90, remplacez le signal par un signal SIGTERM tel que, 15.
90 while kill -15 $PID 2>/dev/null
Ensuite, il n'y aura aucun retard lors du démarrage/arrêt du calmar:
$ time /etc/init.d/squid3 stop
[ ok ] Stopping Squid HTTP Proxy 3.x: squid3.
real 0m2.036s
user 0m0.004s
sys 0m0.000s
$ time /etc/init.d/squid3 start
[ ok ] Starting Squid HTTP Proxy 3.x: squid3.
real 0m0.036s
user 0m0.004s
sys 0m0.004s
Attention: bien qu'il fournisse un démarrage/arrêt rapide pour le service, cette solution de contournement pourrait casser l'objectif du script, qui utilise le signal 0 pour ses propres raisons.