Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
242d8e09
Commit
242d8e09
authored
Sep 09, 2012
by
Alexander Belopolsky
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Issue #15881: Fixed atexit hook in multiprocessing.
parent
a1772f7f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
33 additions
and
9 deletions
+33
-9
Doc/ACKS.txt
Doc/ACKS.txt
+1
-0
Lib/multiprocessing/util.py
Lib/multiprocessing/util.py
+32
-9
No files found.
Doc/ACKS.txt
View file @
242d8e09
...
...
@@ -238,3 +238,4 @@ docs@python.org), and we'll be glad to correct the problem.
* Moshe Zadka
* Milan Zamazal
* Cheng Zhang
* Chris McDonough
Lib/multiprocessing/util.py
View file @
242d8e09
...
...
@@ -235,6 +235,12 @@ def _run_finalizers(minpriority=None):
Finalizers with highest priority are called first; finalizers with
the same priority will be called in reverse order of creation.
'''
if
_finalizer_registry
is
None
:
# This function may be called after this module's globals are
# destroyed. See the _exit_function function in this module for more
# notes.
return
if
minpriority
is
None
:
f
=
lambda
p
:
p
[
0
][
0
]
is
not
None
else
:
...
...
@@ -266,7 +272,13 @@ def is_exiting():
_exiting
=
False
def
_exit_function
():
def
_exit_function
(
info
=
info
,
debug
=
debug
,
_run_finalizers
=
_run_finalizers
,
active_children
=
active_children
,
current_process
=
current_process
):
# We hold on to references to functions in the arglist due to the
# situation described below, where this function is called after this
# module's globals are destroyed.
global
_exiting
if
not
_exiting
:
...
...
@@ -276,14 +288,25 @@ def _exit_function():
debug
(
'running all "atexit" finalizers with priority >= 0'
)
_run_finalizers
(
0
)
for
p
in
active_children
():
if
p
.
_daemonic
:
info
(
'calling terminate() for daemon %s'
,
p
.
name
)
p
.
_popen
.
terminate
()
for
p
in
active_children
():
info
(
'calling join() for process %s'
,
p
.
name
)
p
.
join
()
if
current_process
()
is
not
None
:
# We check if the current process is None here because if
# it's None, any call to ``active_children()`` will throw an
# AttributeError (active_children winds up trying to get
# attributes from util._current_process). This happens in a
# variety of shutdown circumstances that are not well-understood
# because module-scope variables are not apparently supposed to
# be destroyed until after this function is called. However,
# they are indeed destroyed before this function is called. See
# issues #9775 and #15881. Also related: #4106, #9205, and #9207.
for
p
in
active_children
():
if
p
.
_daemonic
:
info
(
'calling terminate() for daemon %s'
,
p
.
name
)
p
.
_popen
.
terminate
()
for
p
in
active_children
():
info
(
'calling join() for process %s'
,
p
.
name
)
p
.
join
()
debug
(
'running the remaining "atexit" finalizers'
)
_run_finalizers
()
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment