當前位置: 首頁>>代碼示例>>Python>>正文


Python Pool.grow方法代碼示例

本文整理匯總了Python中pool.Pool.grow方法的典型用法代碼示例。如果您正苦於以下問題:Python Pool.grow方法的具體用法?Python Pool.grow怎麽用?Python Pool.grow使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在pool.Pool的用法示例。


在下文中一共展示了Pool.grow方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: Guard

# 需要導入模塊: from pool import Pool [as 別名]
# 或者: from pool.Pool import grow [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)
開發者ID:demien-aa,項目名稱:popcorn,代碼行數:84,代碼來源:__init__.py


注:本文中的pool.Pool.grow方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。