Я змінив сценарій, відповідальний за надсилання сигналу вбивства з виділеною затримкою, /etc/init.d/sendsigs, і зменшив кількість часу, який він робить для вбивства решти процесів за 2 ітерації. Здоровий чи ні, він виконує роботу в моїй системі і більше не висить при відключенні та перезапуску.
Нижче представлена частина /etc/init.d/sendsigs з модифікацією, зазначеною # <---:
# Kill all processes.
log_action_begin_msg "Asking all remaining processes to terminate"
killall5 -15 $OMITPIDS # SIGTERM
log_action_end_msg 0
alldead=""
OMITPIDS0="$OMITPIDS"
#for seq in 1 2 3 4 5 6 7 8 9 10; do # this is the original line
for seq in 1 2; do # <--- the above line is replaced by this one.
потім в нижній частині сценарію:
# Upstart has a method to set a kill timeout and so the job author
# may want us to wait longer than 10 seconds (as in the case of
# mysql). (LP: #688541)
#
# We will wait up to 300 seconds for any jobs in stop/killed state.
# Any kill timeout higher than that will be overridden by the need
# to shutdown. NOTE the re-use of seq from above, since we already
# waited up to 10 seconds for them.
while [ -n "$(upstart_killed_jobs)" ] ; do
seq=$(($seq+1))
#if [ $seq -ge 300 ] ; then # this is the original line
if [ $seq -ge 2 ] ; then # <--- I can't wait for another 300 iteration
break
fi
ПРИМІТКА: Це може бути не найкращим рішенням, оскільки оригінальний скрипт працює в інших системах, для таких систем, як моя, де кілька запропонованих рішень не застосовувалися - це те, що я можу поділитися, враховуючи, що я запускаю систему лише як робочу станцію без критичні сервіси, що працюють після закриття всіх настільних додатків, які я використовую перед натисканням піктограми вимкнення або перезавантаження.
Використовувана система - ноутбук Asus X550DP.
sudo shutdown -h now
і побачити, чи повністю він вимикається.