web-dev-qa-db-fra.com

démarrer / arrêter de prendre trop de temps

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?

6
nixnotwin

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.

http://www.squid-cache.org/Doc/config/shutdown_lifetime/

12
Chris Woollard

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.

0
ivanleoncz