Zmodyfikowałem skrypt odpowiedzialny za wysyłanie sygnału zabicia z przydzielonym opóźnieniem, /etc/init.d/sendsigs, i skróciłem czas potrzebny na zabicie pozostałych procesów w 2 iteracjach. Zdrowe czy nie, wykonuje zadanie w moim systemie i nie przestaje już działać przy wyłączaniu i ponownym uruchomieniu.
Poniżej znajduje się część pliku /etc/init.d/sendsigs z modyfikacjami oznaczonymi # <---:
# 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.
następnie w dolnej części skryptu:
# 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
UWAGA: To może nie być najlepsze rozwiązanie, ponieważ oryginalny skrypt działa na innych systemach, dla takich systemów, jak mój, w których nie zastosowano kilku sugerowanych rozwiązań - to mogę udostępnić, biorąc pod uwagę, że działam tylko jako stacja robocza bez krytyczne usługi działające po zamknięciu wszystkich aplikacji komputerowych, z których korzystam przed kliknięciem ikony zamykania lub restartowania.
System w użyciu to laptop Asus X550DP.
sudo shutdown -h now
i sprawdzić, czy się całkowicie wyłącza.