URL: https://www.opennet.me/cgi-bin/openforum/vsluhboard.cgi
Форум: vsluhforumID9
Нить номер: 7841
[ Назад ]

Исходное сообщение
"Не доходят сигналы после выполнения system"

Отправлено max26 , 20-Янв-09 11:00 
Есть демон, делаю систему обновления. После того как бинарник залит демон должен перезапустить себя. Посылаем сигнал терм kill(pid,SIGTERM), в обработчике делаем

void sighandler_terminate(int s) {
....
system(path_to_demon);
exit(0);
}

все замечательно, демон перезапускается, нормально работает за один исключением - он перестает принимать сигналы. Посылаем сигнал из консоли killall demonname и облом. Понятное дело killall -9 demonname работает. Что делать? Где пропадают сигналы?


Содержание

Сообщения в этом обсуждении
"Не доходят сигналы после выполнения system"
Отправлено mikra , 20-Янв-09 11:18 
>[оверквотинг удален]
>
>void sighandler_terminate(int s) {
>....
>system(path_to_demon);
>exit(0);
>}
>
>все замечательно, демон перезапускается, нормально работает за один исключением - он перестает
>принимать сигналы. Посылаем сигнал из консоли killall demonname и облом. Понятное
>дело killall -9 demonname работает. Что делать? Где пропадают сигналы?

Тоесть при живом демоне стартует второй, а пока он запускается первый умирает? Мило. А если изменить производительность хоста, будет работать?


"Не доходят сигналы после выполнения system"
Отправлено max26 , 20-Янв-09 11:28 

>Тоесть при живом демоне стартует второй, а пока он запускается первый умирает?
>Мило. А если изменить производительность хоста, будет работать?

Команда system ожидает завершения процесса. Значит второй в любом случае успеет стартовать. Или я не о том?


"Не доходят сигналы после выполнения system"
Отправлено mikra , 20-Янв-09 11:38 
>
>>Тоесть при живом демоне стартует второй, а пока он запускается первый умирает?
>>Мило. А если изменить производительность хоста, будет работать?
>
>Команда system ожидает завершения процесса. Значит второй в любом случае успеет стартовать.
>Или я не о том?

Не о том. Предлагаю поставить опыт. В начале кода сделай слип секунд 10. Тоесть при старте демона первое что он делает - не перехват сигналов, не чтение конфигов или инициализация переменных, а слип. А потом посмотрим как все будет работать. Может я и ошибаюсь, но вдруг в  алгоритме возникают накладки из-за одновременной работы двух процессов?


"Не доходят сигналы после выполнения system"
Отправлено vic , 20-Янв-09 13:45 
>void sighandler_terminate(int s) {
>....
>system(path_to_demon);
>exit(0);
>}

аццкая жесть.
читать man signal
читать концепцию сигналов Posix тут хотя бы http://www.unix.org/single_unix_specification/

в обработчике сигнала _нельзя_ вызывать system(неявно fork) и exit().


"Не доходят сигналы после выполнения system"
Отправлено const86 , 21-Янв-09 14:48 
>в обработчике сигнала _нельзя_ вызывать system(неявно fork) и exit().

А вот мне man 7 signal говорит, ссылаясь на posix, что fork и _exit можно. Другое дело. что здесь форк не нужен, а system его делает.


"Не доходят сигналы после выполнения system"
Отправлено vic , 21-Янв-09 15:51 
>>в обработчике сигнала _нельзя_ вызывать system(неявно fork) и exit().
>
>А вот мне man 7 signal говорит, ссылаясь на posix, что fork
>и _exit можно. Другое дело. что здесь форк не нужен, а
>system его делает.

да верно, однако exit() и _exit() это не одно и тоже.
system() нельзя, а сам fork() явно можно.
В неявном виде (в system()) могут производится какие-то unsafe действия.


"Не доходят сигналы после выполнения system"
Отправлено const86 , 21-Янв-09 16:43 
Теперь согласен :)

"Не доходят сигналы после выполнения system"
Отправлено const86 , 21-Янв-09 14:46 
>system(path_to_demon);

exec