Sending SIGINT to process groups sometimes gets ignored

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
4
down vote

favorite
1












I start a process group from bash. Then I send SIGINT to the entire process
group. Sometimes the SIGINT kills the processes, sometimes does not. Why does
SIGINT sometimes gets ignored ?



I see different behavior depending on whether the process group is started in
the background or not, on nestedness of bash shells and on Mac/Linux operating
system. I would really appreciate if someone can shed some light on this.



In the following examples I use this python executable called sleep_in_pgrp.py



#!/usr/bin/env python2.7
import os;
import subprocess
os.setpgrp();
subprocess.check_call(["sleep","10000"]);


It creates a process group and starts sleep. The observed phenomena should not
be related to python. I use python only because bash does not have a setpgrp
command or builtin. Update: Apparently one could also run an interactive
shell to create a new process group



1) Start the process group in the background and wait on the leader. SIGINT gets ignored.



Execute the following command:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


Bash starts python in the background and waits on it.
In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2963 2507 2507 -bash
2963 2507 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2964 2963 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2965 2964 2963 2965 2507 python2.7 ./sleep_in_pgrp.py
2966 2965 2963 2965 2507 sleep 10000


SIGINT’ing the proccess group of python does not kill any processes. What can be the reason ?



$ sudo kill -s SIGINT -- -2965


2) Start the process group in the foreground. SIGINT works.



If I remove the & wait $!, SIGINT kills the process group as expected. I do not know why but I am not surprised SIGINT killed the processes in this case.



$ bash -c ' sleep_in_pgrp.py; '


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 3352 2507 2507 -bash
3352 2507 3352 3352 2507 bash -c sleep_in_pgrp.py;
3353 3352 3352 3353 2507 python2.7 ./sleep_in_pgrp.py
3354 3353 3352 3353 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -3353


3) Removing the subshell while running python in the background. SIGINT works.



I was very surprised that the shell nestedness affects the behavior here. I cannot think of any explanation why.



I remove the bash -c at the start:



$ sleep_in_pgrp.py; & wait $!


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2507 2507 2507 -bash
3488 2507 2507 3488 2507 -bash
3489 3488 2507 3489 2507 python2.7 ./sleep_in_pgrp.py
3490 3489 2507 3489 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -2507


4) Running the first command in Mac: SIGINT works.



The first 2 commands ran in a CentOs7 VM.



$ uname -a
Linux ip-10-229-193-124 3.10.0-693.5.2.el7.x86_64 #1 SMP Fri Oct 13 10:46:25 EDT 2017 x86_64 x86_64 x86_64 GNU/Linux


I now execute the first command with backgrounded python in a subshell in mac.



$ uname -a
Darwin mbp-005063 15.6.0 Darwin Kernel Version 15.6.0: Sun Jun 4 21:43:07 PDT 2017; root:xnu-3248.70.3~1/RELEASE_X86_64 x86_64


In Mac:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


In another terminal:



$ PID PPID TPGID PGID SESS COMMAND
18741 40096 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18742 18741 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18743 18742 18741 18743 0 /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
18744 18743 18741 18743 0 sleep 10000
40094 2423 18741 40094 0 /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40095 40094 18741 40095 0 /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40096 40095 18741 40096 0 -bash
-+= 00001 root /sbin/launchd
-+= 02423 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2
-+= 40094 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40095 root /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40096 hbaba -bash
-+= 18741 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+- 18742 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+= 18743 hbaba /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
--- 18744 hbaba sleep 10000


And in this case, SIGINT also kills the process group



$ sudo kill -s INT -18743


Bash version in CentOs7 is



$ echo $BASH_VERSION
4.2.46(2)-release


In Mac the bash version is



$ echo $BASH_VERSION
4.4.12(1)-release



This answer explains how
CLTRL-C sends SIGINT to the process group. That is what I am trying to do here
sending SIGINT to a process group.
This answer mentions that non
interactive jobs require a SIGINT handler. I am not sure it explains the
varying behavior I see. I am also wondering whether waiting on a background
process affects the SIGINT handling by that process.







share|improve this question






















  • After writing the question down, I actually see that 2) and 3) result in the same process tree. So it is not surprising that in both cases the SIGINT can kill the process group. But maybe there are other factors there.
    – Hakan Baba
    Oct 29 '17 at 8:08











  • What happens when you add a SIGINT handler to the python code, instead of relying on whatever the shell sets up for that?
    – thrig
    Oct 29 '17 at 14:45










  • Your question would be a lot easier to read if it didn't require horizontal scrolling and de-obfuscating Python scripts. FWIW.
    – Satō Katsura
    Oct 29 '17 at 18:50










  • @SatōKatsura I was also not too happy with the formatting. Any suggestions? I could save the python code in a bash variable and reuse it. Does that sound reasonable? I do not know about the long lines. I did not want to split the long lines in ps output that show a tree.
    – Hakan Baba
    Oct 29 '17 at 18:53










  • You could also write the Python script to a file instead of inlining it. It doesn't make any difference from the point of view of the question.
    – Satō Katsura
    Oct 29 '17 at 18:54














up vote
4
down vote

favorite
1












I start a process group from bash. Then I send SIGINT to the entire process
group. Sometimes the SIGINT kills the processes, sometimes does not. Why does
SIGINT sometimes gets ignored ?



I see different behavior depending on whether the process group is started in
the background or not, on nestedness of bash shells and on Mac/Linux operating
system. I would really appreciate if someone can shed some light on this.



In the following examples I use this python executable called sleep_in_pgrp.py



#!/usr/bin/env python2.7
import os;
import subprocess
os.setpgrp();
subprocess.check_call(["sleep","10000"]);


It creates a process group and starts sleep. The observed phenomena should not
be related to python. I use python only because bash does not have a setpgrp
command or builtin. Update: Apparently one could also run an interactive
shell to create a new process group



1) Start the process group in the background and wait on the leader. SIGINT gets ignored.



Execute the following command:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


Bash starts python in the background and waits on it.
In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2963 2507 2507 -bash
2963 2507 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2964 2963 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2965 2964 2963 2965 2507 python2.7 ./sleep_in_pgrp.py
2966 2965 2963 2965 2507 sleep 10000


SIGINT’ing the proccess group of python does not kill any processes. What can be the reason ?



$ sudo kill -s SIGINT -- -2965


2) Start the process group in the foreground. SIGINT works.



If I remove the & wait $!, SIGINT kills the process group as expected. I do not know why but I am not surprised SIGINT killed the processes in this case.



$ bash -c ' sleep_in_pgrp.py; '


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 3352 2507 2507 -bash
3352 2507 3352 3352 2507 bash -c sleep_in_pgrp.py;
3353 3352 3352 3353 2507 python2.7 ./sleep_in_pgrp.py
3354 3353 3352 3353 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -3353


3) Removing the subshell while running python in the background. SIGINT works.



I was very surprised that the shell nestedness affects the behavior here. I cannot think of any explanation why.



I remove the bash -c at the start:



$ sleep_in_pgrp.py; & wait $!


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2507 2507 2507 -bash
3488 2507 2507 3488 2507 -bash
3489 3488 2507 3489 2507 python2.7 ./sleep_in_pgrp.py
3490 3489 2507 3489 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -2507


4) Running the first command in Mac: SIGINT works.



The first 2 commands ran in a CentOs7 VM.



$ uname -a
Linux ip-10-229-193-124 3.10.0-693.5.2.el7.x86_64 #1 SMP Fri Oct 13 10:46:25 EDT 2017 x86_64 x86_64 x86_64 GNU/Linux


I now execute the first command with backgrounded python in a subshell in mac.



$ uname -a
Darwin mbp-005063 15.6.0 Darwin Kernel Version 15.6.0: Sun Jun 4 21:43:07 PDT 2017; root:xnu-3248.70.3~1/RELEASE_X86_64 x86_64


In Mac:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


In another terminal:



$ PID PPID TPGID PGID SESS COMMAND
18741 40096 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18742 18741 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18743 18742 18741 18743 0 /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
18744 18743 18741 18743 0 sleep 10000
40094 2423 18741 40094 0 /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40095 40094 18741 40095 0 /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40096 40095 18741 40096 0 -bash
-+= 00001 root /sbin/launchd
-+= 02423 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2
-+= 40094 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40095 root /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40096 hbaba -bash
-+= 18741 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+- 18742 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+= 18743 hbaba /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
--- 18744 hbaba sleep 10000


And in this case, SIGINT also kills the process group



$ sudo kill -s INT -18743


Bash version in CentOs7 is



$ echo $BASH_VERSION
4.2.46(2)-release


In Mac the bash version is



$ echo $BASH_VERSION
4.4.12(1)-release



This answer explains how
CLTRL-C sends SIGINT to the process group. That is what I am trying to do here
sending SIGINT to a process group.
This answer mentions that non
interactive jobs require a SIGINT handler. I am not sure it explains the
varying behavior I see. I am also wondering whether waiting on a background
process affects the SIGINT handling by that process.







share|improve this question






















  • After writing the question down, I actually see that 2) and 3) result in the same process tree. So it is not surprising that in both cases the SIGINT can kill the process group. But maybe there are other factors there.
    – Hakan Baba
    Oct 29 '17 at 8:08











  • What happens when you add a SIGINT handler to the python code, instead of relying on whatever the shell sets up for that?
    – thrig
    Oct 29 '17 at 14:45










  • Your question would be a lot easier to read if it didn't require horizontal scrolling and de-obfuscating Python scripts. FWIW.
    – Satō Katsura
    Oct 29 '17 at 18:50










  • @SatōKatsura I was also not too happy with the formatting. Any suggestions? I could save the python code in a bash variable and reuse it. Does that sound reasonable? I do not know about the long lines. I did not want to split the long lines in ps output that show a tree.
    – Hakan Baba
    Oct 29 '17 at 18:53










  • You could also write the Python script to a file instead of inlining it. It doesn't make any difference from the point of view of the question.
    – Satō Katsura
    Oct 29 '17 at 18:54












up vote
4
down vote

favorite
1









up vote
4
down vote

favorite
1






1





I start a process group from bash. Then I send SIGINT to the entire process
group. Sometimes the SIGINT kills the processes, sometimes does not. Why does
SIGINT sometimes gets ignored ?



I see different behavior depending on whether the process group is started in
the background or not, on nestedness of bash shells and on Mac/Linux operating
system. I would really appreciate if someone can shed some light on this.



In the following examples I use this python executable called sleep_in_pgrp.py



#!/usr/bin/env python2.7
import os;
import subprocess
os.setpgrp();
subprocess.check_call(["sleep","10000"]);


It creates a process group and starts sleep. The observed phenomena should not
be related to python. I use python only because bash does not have a setpgrp
command or builtin. Update: Apparently one could also run an interactive
shell to create a new process group



1) Start the process group in the background and wait on the leader. SIGINT gets ignored.



Execute the following command:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


Bash starts python in the background and waits on it.
In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2963 2507 2507 -bash
2963 2507 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2964 2963 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2965 2964 2963 2965 2507 python2.7 ./sleep_in_pgrp.py
2966 2965 2963 2965 2507 sleep 10000


SIGINT’ing the proccess group of python does not kill any processes. What can be the reason ?



$ sudo kill -s SIGINT -- -2965


2) Start the process group in the foreground. SIGINT works.



If I remove the & wait $!, SIGINT kills the process group as expected. I do not know why but I am not surprised SIGINT killed the processes in this case.



$ bash -c ' sleep_in_pgrp.py; '


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 3352 2507 2507 -bash
3352 2507 3352 3352 2507 bash -c sleep_in_pgrp.py;
3353 3352 3352 3353 2507 python2.7 ./sleep_in_pgrp.py
3354 3353 3352 3353 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -3353


3) Removing the subshell while running python in the background. SIGINT works.



I was very surprised that the shell nestedness affects the behavior here. I cannot think of any explanation why.



I remove the bash -c at the start:



$ sleep_in_pgrp.py; & wait $!


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2507 2507 2507 -bash
3488 2507 2507 3488 2507 -bash
3489 3488 2507 3489 2507 python2.7 ./sleep_in_pgrp.py
3490 3489 2507 3489 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -2507


4) Running the first command in Mac: SIGINT works.



The first 2 commands ran in a CentOs7 VM.



$ uname -a
Linux ip-10-229-193-124 3.10.0-693.5.2.el7.x86_64 #1 SMP Fri Oct 13 10:46:25 EDT 2017 x86_64 x86_64 x86_64 GNU/Linux


I now execute the first command with backgrounded python in a subshell in mac.



$ uname -a
Darwin mbp-005063 15.6.0 Darwin Kernel Version 15.6.0: Sun Jun 4 21:43:07 PDT 2017; root:xnu-3248.70.3~1/RELEASE_X86_64 x86_64


In Mac:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


In another terminal:



$ PID PPID TPGID PGID SESS COMMAND
18741 40096 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18742 18741 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18743 18742 18741 18743 0 /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
18744 18743 18741 18743 0 sleep 10000
40094 2423 18741 40094 0 /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40095 40094 18741 40095 0 /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40096 40095 18741 40096 0 -bash
-+= 00001 root /sbin/launchd
-+= 02423 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2
-+= 40094 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40095 root /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40096 hbaba -bash
-+= 18741 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+- 18742 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+= 18743 hbaba /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
--- 18744 hbaba sleep 10000


And in this case, SIGINT also kills the process group



$ sudo kill -s INT -18743


Bash version in CentOs7 is



$ echo $BASH_VERSION
4.2.46(2)-release


In Mac the bash version is



$ echo $BASH_VERSION
4.4.12(1)-release



This answer explains how
CLTRL-C sends SIGINT to the process group. That is what I am trying to do here
sending SIGINT to a process group.
This answer mentions that non
interactive jobs require a SIGINT handler. I am not sure it explains the
varying behavior I see. I am also wondering whether waiting on a background
process affects the SIGINT handling by that process.







share|improve this question














I start a process group from bash. Then I send SIGINT to the entire process
group. Sometimes the SIGINT kills the processes, sometimes does not. Why does
SIGINT sometimes gets ignored ?



I see different behavior depending on whether the process group is started in
the background or not, on nestedness of bash shells and on Mac/Linux operating
system. I would really appreciate if someone can shed some light on this.



In the following examples I use this python executable called sleep_in_pgrp.py



#!/usr/bin/env python2.7
import os;
import subprocess
os.setpgrp();
subprocess.check_call(["sleep","10000"]);


It creates a process group and starts sleep. The observed phenomena should not
be related to python. I use python only because bash does not have a setpgrp
command or builtin. Update: Apparently one could also run an interactive
shell to create a new process group



1) Start the process group in the background and wait on the leader. SIGINT gets ignored.



Execute the following command:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


Bash starts python in the background and waits on it.
In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2963 2507 2507 -bash
2963 2507 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2964 2963 2963 2963 2507 bash -c sleep_in_pgrp.py; & wait $!
2965 2964 2963 2965 2507 python2.7 ./sleep_in_pgrp.py
2966 2965 2963 2965 2507 sleep 10000


SIGINT’ing the proccess group of python does not kill any processes. What can be the reason ?



$ sudo kill -s SIGINT -- -2965


2) Start the process group in the foreground. SIGINT works.



If I remove the & wait $!, SIGINT kills the process group as expected. I do not know why but I am not surprised SIGINT killed the processes in this case.



$ bash -c ' sleep_in_pgrp.py; '


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 3352 2507 2507 -bash
3352 2507 3352 3352 2507 bash -c sleep_in_pgrp.py;
3353 3352 3352 3353 2507 python2.7 ./sleep_in_pgrp.py
3354 3353 3352 3353 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -3353


3) Removing the subshell while running python in the background. SIGINT works.



I was very surprised that the shell nestedness affects the behavior here. I cannot think of any explanation why.



I remove the bash -c at the start:



$ sleep_in_pgrp.py; & wait $!


In another terminal:



$ ps -Heo pid,ppid,tpgid,pgid,sid,user,args
PID PPID TPGID PGID SID COMMAND
2507 1574 2507 2507 2507 -bash
3488 2507 2507 3488 2507 -bash
3489 3488 2507 3489 2507 python2.7 ./sleep_in_pgrp.py
3490 3489 2507 3489 2507 sleep 10000


SIGINT kills the process group.



$ sudo kill -s SIGINT -- -2507


4) Running the first command in Mac: SIGINT works.



The first 2 commands ran in a CentOs7 VM.



$ uname -a
Linux ip-10-229-193-124 3.10.0-693.5.2.el7.x86_64 #1 SMP Fri Oct 13 10:46:25 EDT 2017 x86_64 x86_64 x86_64 GNU/Linux


I now execute the first command with backgrounded python in a subshell in mac.



$ uname -a
Darwin mbp-005063 15.6.0 Darwin Kernel Version 15.6.0: Sun Jun 4 21:43:07 PDT 2017; root:xnu-3248.70.3~1/RELEASE_X86_64 x86_64


In Mac:



$ bash -c ' sleep_in_pgrp.py; & wait $! '


In another terminal:



$ PID PPID TPGID PGID SESS COMMAND
18741 40096 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18742 18741 18741 18741 0 bash -c sleep_in_pgrp.py; & wait $!
18743 18742 18741 18743 0 /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
18744 18743 18741 18743 0 sleep 10000
40094 2423 18741 40094 0 /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40095 40094 18741 40095 0 /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
40096 40095 18741 40096 0 -bash
-+= 00001 root /sbin/launchd
-+= 02423 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2
-+= 40094 hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --server /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40095 root /usr/bin/login -fpl hbaba /Applications/iTerm.app/Contents/MacOS/iTerm2 --launch_shell
-+= 40096 hbaba -bash
-+= 18741 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+- 18742 hbaba bash -c sleep_in_pgrp.py; & wait $!
-+= 18743 hbaba /usr/local/Cellar/python/2.7.12_2/Frameworks/Python.framework/Versions/2.7/Resources/Python.app/Contents/MacOS/Python ./sleep_in_pgrp.py
--- 18744 hbaba sleep 10000


And in this case, SIGINT also kills the process group



$ sudo kill -s INT -18743


Bash version in CentOs7 is



$ echo $BASH_VERSION
4.2.46(2)-release


In Mac the bash version is



$ echo $BASH_VERSION
4.4.12(1)-release



This answer explains how
CLTRL-C sends SIGINT to the process group. That is what I am trying to do here
sending SIGINT to a process group.
This answer mentions that non
interactive jobs require a SIGINT handler. I am not sure it explains the
varying behavior I see. I am also wondering whether waiting on a background
process affects the SIGINT handling by that process.









share|improve this question













share|improve this question




share|improve this question








edited Oct 31 '17 at 23:22

























asked Oct 29 '17 at 8:03









Hakan Baba

244215




244215











  • After writing the question down, I actually see that 2) and 3) result in the same process tree. So it is not surprising that in both cases the SIGINT can kill the process group. But maybe there are other factors there.
    – Hakan Baba
    Oct 29 '17 at 8:08











  • What happens when you add a SIGINT handler to the python code, instead of relying on whatever the shell sets up for that?
    – thrig
    Oct 29 '17 at 14:45










  • Your question would be a lot easier to read if it didn't require horizontal scrolling and de-obfuscating Python scripts. FWIW.
    – Satō Katsura
    Oct 29 '17 at 18:50










  • @SatōKatsura I was also not too happy with the formatting. Any suggestions? I could save the python code in a bash variable and reuse it. Does that sound reasonable? I do not know about the long lines. I did not want to split the long lines in ps output that show a tree.
    – Hakan Baba
    Oct 29 '17 at 18:53










  • You could also write the Python script to a file instead of inlining it. It doesn't make any difference from the point of view of the question.
    – Satō Katsura
    Oct 29 '17 at 18:54
















  • After writing the question down, I actually see that 2) and 3) result in the same process tree. So it is not surprising that in both cases the SIGINT can kill the process group. But maybe there are other factors there.
    – Hakan Baba
    Oct 29 '17 at 8:08











  • What happens when you add a SIGINT handler to the python code, instead of relying on whatever the shell sets up for that?
    – thrig
    Oct 29 '17 at 14:45










  • Your question would be a lot easier to read if it didn't require horizontal scrolling and de-obfuscating Python scripts. FWIW.
    – Satō Katsura
    Oct 29 '17 at 18:50










  • @SatōKatsura I was also not too happy with the formatting. Any suggestions? I could save the python code in a bash variable and reuse it. Does that sound reasonable? I do not know about the long lines. I did not want to split the long lines in ps output that show a tree.
    – Hakan Baba
    Oct 29 '17 at 18:53










  • You could also write the Python script to a file instead of inlining it. It doesn't make any difference from the point of view of the question.
    – Satō Katsura
    Oct 29 '17 at 18:54















After writing the question down, I actually see that 2) and 3) result in the same process tree. So it is not surprising that in both cases the SIGINT can kill the process group. But maybe there are other factors there.
– Hakan Baba
Oct 29 '17 at 8:08





After writing the question down, I actually see that 2) and 3) result in the same process tree. So it is not surprising that in both cases the SIGINT can kill the process group. But maybe there are other factors there.
– Hakan Baba
Oct 29 '17 at 8:08













What happens when you add a SIGINT handler to the python code, instead of relying on whatever the shell sets up for that?
– thrig
Oct 29 '17 at 14:45




What happens when you add a SIGINT handler to the python code, instead of relying on whatever the shell sets up for that?
– thrig
Oct 29 '17 at 14:45












Your question would be a lot easier to read if it didn't require horizontal scrolling and de-obfuscating Python scripts. FWIW.
– Satō Katsura
Oct 29 '17 at 18:50




Your question would be a lot easier to read if it didn't require horizontal scrolling and de-obfuscating Python scripts. FWIW.
– Satō Katsura
Oct 29 '17 at 18:50












@SatōKatsura I was also not too happy with the formatting. Any suggestions? I could save the python code in a bash variable and reuse it. Does that sound reasonable? I do not know about the long lines. I did not want to split the long lines in ps output that show a tree.
– Hakan Baba
Oct 29 '17 at 18:53




@SatōKatsura I was also not too happy with the formatting. Any suggestions? I could save the python code in a bash variable and reuse it. Does that sound reasonable? I do not know about the long lines. I did not want to split the long lines in ps output that show a tree.
– Hakan Baba
Oct 29 '17 at 18:53












You could also write the Python script to a file instead of inlining it. It doesn't make any difference from the point of view of the question.
– Satō Katsura
Oct 29 '17 at 18:54




You could also write the Python script to a file instead of inlining it. It doesn't make any difference from the point of view of the question.
– Satō Katsura
Oct 29 '17 at 18:54










1 Answer
1






active

oldest

votes

















up vote
0
down vote













It's so possible that this process capture SIGINT signal to use with other function.



The process only dead if the signal received is unknown for it. But, if process set a function linked to this signal, It will don't dead, unless the function linked to this signal finish the program.



By example, a simply C program:



 #include <signal.h>

int sigreceived = 0;

void mysignal();

int main()
signal(2, mysignal); //SIGINT corresponds to 2 signal

while(1);
return 0;


void mysignal()
sigreceived=1;



In this program, signal 2 is captured to call mysignal function what, instead kill the process, simply change the value of a variable



Then, this process don't kill with SIGINT






share|improve this answer






















    Your Answer







    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "106"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    convertImagesToLinks: false,
    noModals: false,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













     

    draft saved


    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f401169%2fsending-sigint-to-process-groups-sometimes-gets-ignored%23new-answer', 'question_page');

    );

    Post as a guest






























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    0
    down vote













    It's so possible that this process capture SIGINT signal to use with other function.



    The process only dead if the signal received is unknown for it. But, if process set a function linked to this signal, It will don't dead, unless the function linked to this signal finish the program.



    By example, a simply C program:



     #include <signal.h>

    int sigreceived = 0;

    void mysignal();

    int main()
    signal(2, mysignal); //SIGINT corresponds to 2 signal

    while(1);
    return 0;


    void mysignal()
    sigreceived=1;



    In this program, signal 2 is captured to call mysignal function what, instead kill the process, simply change the value of a variable



    Then, this process don't kill with SIGINT






    share|improve this answer


























      up vote
      0
      down vote













      It's so possible that this process capture SIGINT signal to use with other function.



      The process only dead if the signal received is unknown for it. But, if process set a function linked to this signal, It will don't dead, unless the function linked to this signal finish the program.



      By example, a simply C program:



       #include <signal.h>

      int sigreceived = 0;

      void mysignal();

      int main()
      signal(2, mysignal); //SIGINT corresponds to 2 signal

      while(1);
      return 0;


      void mysignal()
      sigreceived=1;



      In this program, signal 2 is captured to call mysignal function what, instead kill the process, simply change the value of a variable



      Then, this process don't kill with SIGINT






      share|improve this answer
























        up vote
        0
        down vote










        up vote
        0
        down vote









        It's so possible that this process capture SIGINT signal to use with other function.



        The process only dead if the signal received is unknown for it. But, if process set a function linked to this signal, It will don't dead, unless the function linked to this signal finish the program.



        By example, a simply C program:



         #include <signal.h>

        int sigreceived = 0;

        void mysignal();

        int main()
        signal(2, mysignal); //SIGINT corresponds to 2 signal

        while(1);
        return 0;


        void mysignal()
        sigreceived=1;



        In this program, signal 2 is captured to call mysignal function what, instead kill the process, simply change the value of a variable



        Then, this process don't kill with SIGINT






        share|improve this answer














        It's so possible that this process capture SIGINT signal to use with other function.



        The process only dead if the signal received is unknown for it. But, if process set a function linked to this signal, It will don't dead, unless the function linked to this signal finish the program.



        By example, a simply C program:



         #include <signal.h>

        int sigreceived = 0;

        void mysignal();

        int main()
        signal(2, mysignal); //SIGINT corresponds to 2 signal

        while(1);
        return 0;


        void mysignal()
        sigreceived=1;



        In this program, signal 2 is captured to call mysignal function what, instead kill the process, simply change the value of a variable



        Then, this process don't kill with SIGINT







        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Feb 20 at 10:32

























        answered Feb 20 at 10:24









        AlmuHS

        1447




        1447



























             

            draft saved


            draft discarded















































             


            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f401169%2fsending-sigint-to-process-groups-sometimes-gets-ignored%23new-answer', 'question_page');

            );

            Post as a guest













































































            Popular posts from this blog

            How to check contact read email or not when send email to Individual?

            How many registers does an x86_64 CPU actually have?

            Nur Jahan