На моей машине с Ubuntu у меня есть squid3 в качестве демона, который запускается при загрузке.
Проблема в том, что squid3 занимает много времени для запуска и остановки (более 30 секунд), а также значительно замедляет время запуска / завершения работы моей ОС.
Как я могу решить эту проблему?
Существует параметр с именем shutdown_lifetime. Значение по умолчанию составляет 30 секунд.
Таким образом, когда Squid получает запрос на отключение, он ждет не менее 30 секунд, прежде чем завершится.
$ 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
Просто «раскомментируйте» последнюю строку и установите более короткое время:
shutdown_lifetime 10 seconds
Подробнее см. Ниже.
Я нашел это для пакета Squid 3.1.20-2.2 для 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...
, эта функция использует этот нераспознанный сигнал (0).
Обходной путь: в строке 90 измените сигнал на сигнал SIGTERM, например, 15.
90 while kill -15 $PID 2>/dev/null
Тогда не будет никаких задержек при запуске / остановке Squid:
$ 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
Остерегайтесь : хотя он обеспечивает быстрый запуск / останов для служба, этот обходной путь может нарушить цель сценария, который использует сигнал 0 по своим собственным причинам.