-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathpool.py
40 lines (28 loc) · 1.07 KB
/
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
from multiprocessing import Process, Queue
def worker(name, evalfunc, querries, answers):
while True:
querry = querries.get()
#print("worker ", name, "evaluating")
answer = evalfunc(querry)
#print("worker ", name, "finished")
answers.put(answer)
class Pool:
""" Pool of workers. Workers consume tasks from the querries queue and
feed answers to the answers queue.
"""
def __init__(self, processors, evalfunc):
self.querries = Queue()
self.answers = Queue()
self.workers = []
for i in range(processors):
worker_i = Process(target=worker, args=(i, evalfunc, self.querries, self.answers))
self.workers.append(worker_i)
worker_i.start() # Launch worker() as a separate python process
def putQuerry(self, querry):
self.querries.put(querry)
def getAnswer(self):
return self.answers.get()
def close(self):
for w in self.workers:
w.terminate()
#print("pool killed")