This repository has been archived by the owner on Oct 21, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
safe_pool.py
26 lines (23 loc) · 1.61 KB
/
safe_pool.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
############################################################################
# #
# Copyright (c) 2017 eBay Inc. #
# #
# Licensed under the Apache License, Version 2.0 (the "License"); #
# you may not use this file except in compliance with the License. #
# You may obtain a copy of the License at #
# #
# http://www.apache.org/licenses/LICENSE-2.0 #
# #
# Unless required by applicable law or agreed to in writing, software #
# distributed under the License is distributed on an "AS IS" BASIS, #
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
# See the License for the specific language governing permissions and #
# limitations under the License. #
# #
############################################################################
# The normal multiprocessing.Pool isn't safe because we set signal handlers,
# so we clear our SIGTERM handler for the workers here.
from multiprocessing import Pool as PyPool
from signal import signal, SIGTERM, SIG_DFL
def Pool(processes=None):
return PyPool(processes=processes, initializer=signal, initargs=(SIGTERM, SIG_DFL,))