Bug #5556
closedSIGHUP no longer ignored when sent to process group from a subprocess
Description
Hi,
Prior to 2.0.0dev, this script:
sasha:rubinius brian$ cat process.rb
puts "before system"
system("ruby -e 'Process.kill(:HUP, 0)'")
puts "after system"
would print the following:
sasha:rubinius brian$ ruby1.9.2 -v process.rb
ruby 1.9.2p290 (2011-07-09 revision 32553) [x86_64-darwin10.8.0]
before system
after system
Basically, SIGHUP was ignored when sent from a subprocess. Presently, this is the result:
sasha:rubinius brian$ ruby -v process.rb
ruby 2.0.0dev (2011-11-01 trunk 33596) [x86_64-darwin10.8.0]
before system
Hangup
The following issue may be related, but the explanation is in Japanese, so I cannot follow it: http://redmine.ruby-lang.org/issues/4765
Is this change intentional? I discovered it running RubySpec, where there are specs for the behavior of sending SIGHUP to the process group.
Thanks,
Brian
Updated by kosaki (Motohiro KOSAKI) about 13 years ago
- Category set to core
- Status changed from Open to Assigned
- Assignee set to kosaki (Motohiro KOSAKI)
- Target version set to 2.0.0
Updated by kosaki (Motohiro KOSAKI) about 13 years ago
Is this change intentional? I discovered it running RubySpec, where there are specs for the behavior of sending SIGHUP to the process group.
In short. Yes, intentional. SIGHUP ignorance is mimic of csh. but current almost modern shell nor other scripting language (e.g. perl) don't have such feature. and then, any userland programs don't depend on that a parent process ignore SIGHUP.
Do you have any usecase of SIGHUP? If you have real world usecause, you might be able to persuade us.
Thank you.
Updated by kosaki (Motohiro KOSAKI) about 13 years ago
- Status changed from Assigned to Feedback
Updated by kosaki (Motohiro KOSAKI) about 13 years ago
In addition, signal handler is per-process resource. iow, changing sighandler is thread unsafe. then, we don't want unnecessary sighandler change. that's why I ask you usecase.
Updated by brixen (Brian Shirai) about 13 years ago
The use case is any reason someone would send a signal to the process group but not want the parent process to abort. I'm quite sure there is existing code that depends on this behavior even by accident. The fact that it changed will affect some programs that have previously not ignored HUP, so people will likely get puzzling process exits in cases such as I discovered here by accident, ie on process subprocessing worker processes.
I really don't care what the behavior is as long as it is documented and tested. If you can point me to tests for this, I'll adapt them for RubySpec.
I have no idea what you mean by "signal handler is per-process resource", how would it not be a per-process resource? Or do you have a definition of per-process where process is not an OS process? How does per-process and thread-safety relate? Seems like we should have a glossary of terms as MRI defines them to avoid some confusion here.
Updated by kosaki (Motohiro KOSAKI) about 13 years ago
- ruby -v changed from ruby 2.0.0dev (2011-11-01 trunk 33596) [x86_64-darwin10.8.0] to -
The use case is any reason someone would send a signal to the process group but not want the parent process to abort. I'm quite sure there is existing code that depends on this behavior even by accident. The fact that it changed will affect some programs that have previously not ignored HUP, so people will likely get puzzling process exits in cases such as I discovered here by accident, ie on process subprocessing worker processes.
Guys, I asked you practical and real world usecase.
I really don't care what the behavior is as long as it is documented and tested. If you can point me to tests for this, I'll adapt them for RubySpec.
I have no idea what you mean by "signal handler is per-process resource", how would it not be a per-process resource? Or do you have a definition of per-process where process is not an OS process? How does per-process and thread-safety relate? Seems like we should have a glossary of terms as MRI defines them to avoid some confusion here.
man sigaction.
Updated by brixen (Brian Shirai) about 13 years ago
Apparently, I don't have a "practical and real world usecase" as a change in the behavior of running RubySpec doesn't qualify.
This change will potentially affect any program that subprocesses workers. If that's fine with you, great.
I'm simply asking for the change to be documented with tests. Do you have those?
man sigaction.
That is unhelpful. I know what sigaction does. What is your definition of a "process" and why is changing the sighandler not thread-safe?
Updated by kosaki (Motohiro KOSAKI) about 12 years ago
- Assignee deleted (
kosaki (Motohiro KOSAKI))
Updated by ko1 (Koichi Sasada) almost 12 years ago
- Assignee set to mame (Yusuke Endoh)
Updated by mame (Yusuke Endoh) almost 12 years ago
- Assignee changed from mame (Yusuke Endoh) to kosaki (Motohiro KOSAKI)
I don't think that this issue is ready for determining a backport to 2.0.0.
Kosaki-san, what do you think?
--
Yusuke Endoh mame@tsg.ne.jp
Updated by kosaki (Motohiro KOSAKI) almost 12 years ago
- Status changed from Feedback to Closed
No feedback. Close it.