終了時のプロセスブロック

終了時のプロセスブロック

私は、アプリケーションが通常の動作の一部として複数のサブプロセスを生成するDebian Wheezyを実行するシステムを開発しています。ほとんどの場合、親アプリケーションが終了すると、すべての子アプリケーションが消去され、終了します。ただし、コンピュータをシャットダウン/再起動すると、シャットダウンする前に数分間停止することがよくあります。マシンはリモート/ヘッドレスなので、内側から見るのはシステムが終了し、SSHセッションが終了し、ログインしようとすると接続拒否エラーが発生するというメッセージだけです。 /var/log/syslog を参照すると、次の項目が表示されます。 [ 3840.402493] INFO: task child_process:4455 blocked for more than 120 seconds. [ 3840.402579] "echo 0 > /proc/sys/kernel/hung_task_timeout_secs" disables this message. [ 3840.402684] child_process D c109bbf8 0 4455 3702 0x00000000 [ 3840.402691] f79c7b00 00000046 00000001 c109bbf8 f0bed5b0 333f9aaa 00000351 c1483b00 [ 3840.402703] c1483b00 00000292 c109bcf9 00000292 00000000 f2c005a0 00000000 edd1fd34 [ 3840.402714] 00000292 c109bebf c10abe25 00000001 f2bd4740 00000000 00000001 c109bc0a [ 3840.402726] Call Trace: [ 3840.402733] [] ? free_pages_prepare+0xc0/0xf1 [ 3840.402741] [] ? free_hot_cold_page+0x3d/0xf7 [ 3840.402749] [] ? __pagevec_free+0x3e/0x55 [ 3840.402756] [] ? page_address+0x1b/0x85 [ 3840.402763] [] ? free_pages_prepare+0xd2/0xf1 [ 3840.402771] [] ? __mutex_lock_common.isra.6+0x11d/0x132 [ 3840.402778] [] ? mutex_lock+0x15/0x21 [ 3840.402785] [] ? tty_release+0x3d/0x400 [ 3840.402794] [] ? ip_mc_del_src+0xf1/0x12e [ 3840.402801] [] ? ip_mc_leave_src+0x22/0x68 [ 3840.402809] [] ? kmem_cache_free+0x23/0x55 [ 3840.402816] [] ? fput+0xd7/0x161 [ 3840.402822] [] ? filp_close+0x54/0x5a [ 3840.402828] [] ? put_files_struct+0x4b/0x88 [ 3840.402834] [] ? do_exit+0x237/0x60d [ 3840.402842] [] ? recalc_sigpending+0xf/0x2f [ 3840.402849] [] ? dequeue_signal+0xb4/0x126 [ 3840.402855] [] ? do_group_exit+0x56/0x83 [ 3840.402863] [] ? get_signal_to_deliver+0x43b/0x465 [ 3840.402871] [] ? do_signal+0x32/0x52c [ 3840.402879] [] ? update_rmtp+0x45/0x45 [ 3840.402886] [] ? do_futex+0x99/0x6c6 [ 3840.402893] [] ? read_tsc+0xa/0x28 [ 3840.402901] [] ? timekeeping_get_ns+0x10/0x47 [ 3840.402907] [] ? sys_futex+0xbb/0x10f [ 3840.402915] [] ? do_notify_resume+0x1e/0x5c [ 3840.402922] [] ? work_notifysig+0x13/0x1b [ 3840.402929] [] ? start_cpu_timer+0x39/0x62 [ 3840.402935] [] ? vmstat_cpuup_callback+0x18/0x5a 再起動要求が行われた後にシステムが実際にシャットダウンされる前の複数のサブプロセスのエントリ。

関連することができるのは、親アプリケーションが終了した後に子アプリケーションを実行状態にすることがあることです。これらのプロセスを手動で終了するために、デフォルトで次のように構成されたスクリプトがあります。

#!/bin/bash
killall -q parent_process
killall -q child_1
killall -q child_2
#etc...

手動で実行すると、このスクリプトはすべてのプロセスを確実に終了し、中断されません。また、子プロセスを手動で開始しても、この動作は中断または表示されません。

私の直感によると、親アプリケーションが子プロセスを正しくクリーンアップしないのは問題ですが、残念ながら、親プロセスは独自の内部アプリケーションであるため、実装を変更できないため、解決策を見つけようとしました。 。シャットダウン/再起動前にkillallスクリプトを手動で実行してもシャットダウンが遅れないため、終了/再起動時にスクリプトを実行する方法を見つけようとしました。

私の最初の試みは、Killallスクリプトを/etc/init.dにコピーし、K01killstuffでrc0.dとrc6.dに接続することでしたが、うまくいかなかったので、適切なinitスクリプトを作成することにしました。私は/etc/init.dのフレームワークで始まり、次のようになりました:

#! /bin/sh
### BEGIN INIT INFO
# Provides:          killstuff
# Required-Start:    $remote_fs $syslog
# Required-Stop:     $remote_fs $syslog
# Default-Stop:      0 1 6
# Short-Description: Stop applications
# Description:       This file should be used to construct scripts to be
#                    placed in /etc/init.d.
### END INIT INFO

# Author: 
#
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="Description of the service"
NAME=daemonexecutablename
DAEMON=/usr/sbin/$NAME
DAEMON_ARGS="--options args"
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME

# Load the VERBOSE setting and other rcS variables
. /lib/init/vars.sh

# Define LSB log_* functions.
# Depend on lsb-base (>= 3.2-14) to ensure that this file is present
# and status_of_proc is working.
. /lib/lsb/init-functions

#
# Function that stops the daemon/service
#
do_stop()
{
    killall -q parent_process
    killall -q child_1
    killall -q child_2
}


case "$1" in
  start)
    ;;
  stop)
    [ "$VERBOSE" != no ] && log_daemon_msg "Stopping Applications"
    do_stop
    ;;
  status)
    ;;
  restart|force-reload)
    ;;
  *)
    #echo "Usage: $SCRIPTNAME {start|stop|restart|reload|force-reload}" >&2
    echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2
    exit 3
    ;;
esac

:

スクリプトをテストして、/etc/init.d/killstuff stop予想されたすべてのプロセスが終了したことを確認してから、update-rc.d killstuff defaultsリンクがrc0.dとrc6.dに作成されたが、再起動時にシステムがクラッシュすることを確認しました。これにより、これらのプロセスは終了順序の早い段階で終了する必要があると考えました。

では、どこでキルスクリプトを呼び出すことができますか?それとも、システムをよりスムーズにシャットダウンするために、システムがシャットダウンされる前にすべてのアプリケーションをシャットダウンする以外に試すことができる他の方法はありますか?

関連情報