Commit 127c8c74 authored by Paul Ganssle's avatar Paul Ganssle

Limit workers in ProcessPoolExecutor

As a mitigation for #1730, this commit limits the number of workers in
the ProcessPoolExecutor to 1 (default is the number of CPUs). On PyPy,
having a higher number of available workers dramatically increases the
number of concurrent processes, leading to some resource exhaustion
issues.

This does not address the root issue, but should improve the situation
until the root issue is addressed.
parent dd2240a7
...@@ -28,7 +28,7 @@ class BuildBackend(BuildBackendBase): ...@@ -28,7 +28,7 @@ class BuildBackend(BuildBackendBase):
def __init__(self, *args, **kwargs): def __init__(self, *args, **kwargs):
super(BuildBackend, self).__init__(*args, **kwargs) super(BuildBackend, self).__init__(*args, **kwargs)
self.pool = futures.ProcessPoolExecutor() self.pool = futures.ProcessPoolExecutor(max_workers=1)
def __getattr__(self, name): def __getattr__(self, name):
"""Handles aribrary function invocations on the build backend.""" """Handles aribrary function invocations on the build backend."""
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment