diff options
author | Brian Quinlan <brian@sweetapp.com> | 2019-05-08 14:04:53 -0400 |
---|---|---|
committer | Steve Dower <steve.dower@python.org> | 2019-05-08 14:04:53 -0400 |
commit | 39889864c09741909da4ec489459d0197ea8f1fc (patch) | |
tree | 08f7745e5ca5554a14f6b583a4ee8d345d3fe4b7 /Lib/concurrent | |
parent | bpo-24758: Improve the error msg for unittest.mock.Mock()'s unsafe mode (#12991) (diff) | |
download | cpython-39889864c09741909da4ec489459d0197ea8f1fc.tar.gz cpython-39889864c09741909da4ec489459d0197ea8f1fc.tar.bz2 cpython-39889864c09741909da4ec489459d0197ea8f1fc.zip |
bpo-26903: Limit ProcessPoolExecutor to 61 workers on Windows (GH-13132)
Co-Authored-By: brianquinlan <brian@sweetapp.com>
Diffstat (limited to 'Lib/concurrent')
-rw-r--r-- | Lib/concurrent/futures/process.py | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/Lib/concurrent/futures/process.py b/Lib/concurrent/futures/process.py index d7e2478d922..dd14eaec907 100644 --- a/Lib/concurrent/futures/process.py +++ b/Lib/concurrent/futures/process.py @@ -57,6 +57,7 @@ import threading import weakref from functools import partial import itertools +import sys import traceback # Workers are created as daemon threads and processes. This is done to allow the @@ -109,6 +110,12 @@ def _python_exit(): EXTRA_QUEUED_CALLS = 1 +# On Windows, WaitForMultipleObjects is used to wait for processes to finish. +# It can wait on, at most, 63 objects. There is an overhead of two objects: +# - the result queue reader +# - the thread wakeup reader +_MAX_WINDOWS_WORKERS = 63 - 2 + # Hack to embed stringification of remote traceback in local traceback class _RemoteTraceback(Exception): @@ -505,9 +512,16 @@ class ProcessPoolExecutor(_base.Executor): if max_workers is None: self._max_workers = os.cpu_count() or 1 + if sys.platform == 'win32': + self._max_workers = min(_MAX_WINDOWS_WORKERS, + self._max_workers) else: if max_workers <= 0: raise ValueError("max_workers must be greater than 0") + elif (sys.platform == 'win32' and + max_workers > _MAX_WINDOWS_WORKERS): + raise ValueError( + f"max_workers must be <= {_MAX_WINDOWS_WORKERS}") self._max_workers = max_workers |