本文整理匯總了Python中pool.Pool.shrink方法的典型用法代碼示例。如果您正苦於以下問題:Python Pool.shrink方法的具體用法?Python Pool.shrink怎麽用?Python Pool.shrink使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pool.Pool
的用法示例。
在下文中一共展示了Pool.shrink方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: Guard
# 需要導入模塊: from pool import Pool [as 別名]
# 或者: from pool.Pool import shrink [as 別名]
class Guard(BaseApp):
def __init__(self, app, **kwargs):
self.app = app or self.app
super(Guard, self).init(**kwargs)
self.rpc_server = PyroServer(GUARD_PORT)
self.rpc_client = PyroClient(self.app.conf['HUB_IP'], HUB_PORT)
self.pool = Pool(self.app)
self.machine = Machine(healthy_mock=app.conf['HEALTHY_MOCK'], labels=self.labels)
self.__shutdown_guard = threading.Event()
self.LOOP_INTERVAL = 10 # second
self.alive = False
def setup_defaults(self, **_kw):
super(Guard, self).setup_defaults(**_kw)
self.labels = _kw.get('labels', '').split(',') if _kw.get('labels', '') else []
def start(self, condition=lambda: True):
"""
Start the guard.
Setp 1. Start RPC Server
Step 2. Register to hub
Step 3. Start loop
"""
self.__shutdown_guard.clear()
self._start_rpc_server()
self._register_to_hub()
self._start_loop(condition)
def stop(self):
'''
Step 1. Unregister to hub (todo)
Step 2. Stop rpc server
Step 3. Stop the loop
'''
if self.rpc_server.alive:
self.rpc_server.stop()
self.__shutdown_guard.set()
if wait_condition_till_timeout(self.is_alive, 10):
raise CouldNotStopException('guard')
def is_alive(self):
return self.alive
def _start_rpc_server(self):
self.rpc_server.start()
def _register_to_hub(self):
self.rpc_client.call('popcorn.apps.hub.commands.register_machine', machine=self.machine)
def _start_loop(self, condition):
"""
Things to do:
1. Heartbeat to hub
2. Check the orders and follow order
"""
self.alive = True
while not self.__shutdown_guard.isSet() and condition():
try:
self.heartbeat(self.rpc_client)
while ORDERS:
order = ORDERS.pop(0)
debug('[Guard] - [Get Order]: %s' % ','.join([i.cmd for i in order.instructions]))
self.follow_order(order)
except Exception as e:
import traceback; traceback.print_exc()
error('[Guard] - [Exception] - [Loop] : %s. PID: %s' % (e.message, get_pid()))
finally:
time.sleep(self.LOOP_INTERVAL)
self.alive = False
def heartbeat(self, rpc_client):
self.machine.snapshot(self.pool.pinfo)
debug('[Guard] - [Send] - [HeartBeat]')
rpc_client.call('popcorn.apps.hub.commands.update_machine', machine=self.machine)
def follow_order(self, order):
for instruction in order.instructions:
if instruction.operator == Operator.INC:
self.pool.grow(instruction.queue, instruction.worker_cnt)
elif instruction.operator == Operator.DEC:
self.pool.shrink(instruction.queue, instruction.worker_cnt)