Python Multiprocessing And Independence Of Children Processes
Solution 1:
This isn't a matter of how you're invoking python; it's a feature of the multiprocessing
module. When you import that module an exit handler is added to the parent process that calls join()
on the Process
objects of all children created via multiprocessing.Process
before allowing the parent to exit. If you're going to start child processes in this fashion, there's no way, without hacking the module internals, to avoid the behavior that's giving you trouble.
If you want to start a process that's able to outlive the parent, then you'll probably be better served using subprocess.Popen
. If the child's started that way, the parent won't attempt to join the child before exiting and will instead exit immediately, leaving an orphaned child:
>>>from subprocess import Popen>>>Popen(["sleep", "100"])
<subprocess.Popen object at 0x10d3fedd0>
>>>exit()
alp:~ $ ps -opid,ppid,command | grep sleep | grep -v grep
37979 1 sleep 100
Is there a particular reason you're using multiprocessing
instead of subprocess
? The former isn't intended to be used to create child processes meant to outlive the parent; it's for creating child processes to do work that can be usefully parallelized across CPUs, as a way of circumventing the Global Interpreter Lock. (I'm ignoring the distributed capabilities of multiprocessing
for purposes of this discussion.) multiprocessing
is thus normally used in those cases where, if there weren't a GIL, you would use threads. (Note, in this regard, that the multiprocessing
module's API is modeled closely after that of the threading
module.)
To the specific questions at the end of your post: (1) Nothing about python is responsible for killing children when the parent is terminated. A child of the web server will only be killed if the parent kills it before exiting (or if the entire process group is killed). (2) The method you link to looks like it's trying to replicate daemonization without knowledge of the standard idioms for doing that. There are a number of packages out there for creating daemon processes; you should use one of them instead.
Post a Comment for "Python Multiprocessing And Independence Of Children Processes"