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


Python ServiceRunner.add_service方法代碼示例

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


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

示例1: main

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def main():
    config = {
        '_log': LOG,
        'AMQP_URI': 'amqp://guest:[email protected]:5672'
    }
    service_runner = ServiceRunner(config)
    service_runner.add_service(DatabaseService)

    service_runner.start()

    runnlet = eventlet.spawn(service_runner.wait)

    while True:
        try:
            runnlet.wait()
        except OSError as exc:
            if exc.errno == errno.EINTR:
                continue
            raise
        except KeyboardInterrupt:
            try:
                service_runner.stop()
            except KeyboardInterrupt:
                service_runner.kill()
        else:
            break
開發者ID:felippemr,項目名稱:python_zookeeper_lock,代碼行數:28,代碼來源:database_service.py

示例2: test_runner_waits_raises_error

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def test_runner_waits_raises_error(fake_module):
    class Container(object):
        def __init__(self, service_cls, config):
            pass

        def start(self):
            pass

        def stop(self):
            pass

        def wait(self):
            raise Exception('error in container')

    fake_module.ServiceContainer = Container

    config = {'SERVICE_CONTAINER_CLS': 'fake_module.ServiceContainer'}

    runner = ServiceRunner(config=config)
    runner.add_service(TestService1)
    runner.start()

    with pytest.raises(Exception) as exc_info:
        runner.wait()
    assert exc_info.value.args == ('error in container',)
開發者ID:davidszotten,項目名稱:nameko,代碼行數:27,代碼來源:test_service_runner.py

示例3: run_worker

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def run_worker():
    config = get_nameko_config()

    service_runner = ServiceRunner(config)
    service_runner.add_service(RepoWorker)

    service_runner.start()
    service_runner.wait()
開發者ID:jkimbo,項目名稱:cinch,代碼行數:10,代碼來源:nameko_runner.py

示例4: test_config_key

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
    def test_config_key(self, service_cls, container_cls):
        config = {
            'SERVICE_CONTAINER_CLS': "fake_module.ServiceContainerX"
        }
        runner = ServiceRunner(config)
        runner.add_service(service_cls)

        container = get_container(runner, service_cls)
        assert isinstance(container, container_cls)
開發者ID:gwongz,項目名稱:nameko,代碼行數:11,代碼來源:test_service_runner.py

示例5: service_container

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def service_container(patched_db):
    config = {'AMQP_URI': settings.NAMEKO_AMQP_URI}
    runner = ServiceRunner(config)
    runner.add_service(NamekoCollectionService)
    runner.start()

    container = get_container(runner, NamekoCollectionService)
    yield container

    runner.stop()
開發者ID:turc42,項目名稱:pylytics,代碼行數:12,代碼來源:test_nameko.py

示例6: test_runner_lifecycle

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def test_runner_lifecycle(fake_module):
    events = set()

    class Container(object):
        def __init__(self, service_cls, config):
            self.service_name = service_cls.__name__
            self.service_cls = service_cls

        def start(self):
            events.add(('start', self.service_cls.name, self.service_cls))

        def stop(self):
            events.add(('stop', self.service_cls.name, self.service_cls))

        def kill(self):
            events.add(('kill', self.service_cls.name, self.service_cls))

        def wait(self):
            events.add(('wait', self.service_cls.name, self.service_cls))

    fake_module.ServiceContainer = Container

    config = {'SERVICE_CONTAINER_CLS': 'fake_module.ServiceContainer'}
    runner = ServiceRunner(config)

    runner.add_service(TestService1)
    runner.add_service(TestService2)

    runner.start()

    assert events == {
        ('start', 'foobar_1', TestService1),
        ('start', 'foobar_2', TestService2),
    }

    events = set()
    runner.stop()
    assert events == {
        ('stop', 'foobar_1', TestService1),
        ('stop', 'foobar_2', TestService2),
    }

    events = set()
    runner.kill()
    assert events == {
        ('kill', 'foobar_1', TestService1),
        ('kill', 'foobar_2', TestService2),
    }

    events = set()
    runner.wait()
    assert events == {
        ('wait', 'foobar_1', TestService1),
        ('wait', 'foobar_2', TestService2),
    }
開發者ID:davidszotten,項目名稱:nameko,代碼行數:57,代碼來源:test_service_runner.py

示例7: test_runner_lifecycle

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def test_runner_lifecycle():
    events = set()

    class Container(object):
        def __init__(self, service_cls, worker_ctx_cls, config):
            self.service_name = service_cls.__name__
            self.service_cls = service_cls
            self.worker_ctx_cls = worker_ctx_cls

        def start(self):
            events.add(('start', self.service_cls.name, self.service_cls))

        def stop(self):
            events.add(('stop', self.service_cls.name, self.service_cls))

        def kill(self):
            events.add(('kill', self.service_cls.name, self.service_cls))

        def wait(self):
            events.add(('wait', self.service_cls.name, self.service_cls))

    config = {}
    runner = ServiceRunner(config, container_cls=Container)

    runner.add_service(TestService1)
    runner.add_service(TestService2)

    runner.start()

    assert events == {
        ('start', 'foobar_1', TestService1),
        ('start', 'foobar_2', TestService2),
    }

    events = set()
    runner.stop()
    assert events == {
        ('stop', 'foobar_1', TestService1),
        ('stop', 'foobar_2', TestService2),
    }

    events = set()
    runner.kill()
    assert events == {
        ('kill', 'foobar_1', TestService1),
        ('kill', 'foobar_2', TestService2),
    }

    events = set()
    runner.wait()
    assert events == {
        ('wait', 'foobar_1', TestService1),
        ('wait', 'foobar_2', TestService2),
    }
開發者ID:ahmb,項目名稱:nameko,代碼行數:56,代碼來源:test_service_runner.py

示例8: test_kwarg_deprecation_warning

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
    def test_kwarg_deprecation_warning(
        self, warnings, service_cls, container_cls
    ):
        config = {}
        runner = ServiceRunner(config, container_cls=container_cls)
        runner.add_service(service_cls)

        container = get_container(runner, service_cls)
        assert isinstance(container, container_cls)

        # TODO: replace with pytest.warns when eventlet >= 0.19.0 is released
        assert warnings.warn.call_args_list == [call(ANY, DeprecationWarning)]
開發者ID:gwongz,項目名稱:nameko,代碼行數:14,代碼來源:test_service_runner.py

示例9: test_service_integration

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def test_service_integration():
    config = {"AMQP_URI": "amqp://guest:[email protected]:5672/"}
    runner = ServiceRunner(config)
    runner.add_service(ServiceX)
    runner.add_service(ServiceY)
    runner.start()

    container = get_container(runner, ServiceX)

    with entrypoint_hook(container, "remote_method") as entrypoint:
        assert entrypoint("value") == "value-x-y"

    runner.stop()
開發者ID:pombredanne,項目名稱:nameko,代碼行數:15,代碼來源:integration_test.py

示例10: main

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def main():

    logging.basicConfig(level=logging.DEBUG)

    config = {'AMQP_URI': 'amqp://guest:[email protected]:5672/'}
    runner = ServiceRunner(config)
    runner.add_service(HelloWorld)
    runner.add_service(FriendlyService)
    runner.start()
    try:
        runner.wait()
    except KeyboardInterrupt:
        runner.stop()
開發者ID:ahmb,項目名稱:nameko,代碼行數:15,代碼來源:helloworld.py

示例11: main

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def main():
    import logging
    logging.basicConfig(level=logging.DEBUG)

    config = {'AMQP_URI': 'amqp://guest:[email protected]:5672/'}
    runner = ServiceRunner(config)
    runner.add_service(MessagingPublisher)
    runner.start()

    try:
        runner.wait()
    except KeyboardInterrupt:
        runner.stop()
開發者ID:ahmb,項目名稱:nameko,代碼行數:15,代碼來源:messaging_publisher.py

示例12: main

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def main():
    config_dict = get_config_yaml(CONFIG_YAML_PATH)
    c = update_config_yaml(config_dict, CONFIG_YAML_PATH)
    wus = WatchURLService()
    wus.get_config()
    runner = ServiceRunner(c)
    runner.add_service(WatchURLService)
    # container_a = get_container(runner, WatchURLService)
    runner.start()
    try:
        runner.wait()
    except KeyboardInterrupt:
        runner.kill()
    runner.stop()
開發者ID:juga0,項目名稱:watch-url,代碼行數:16,代碼來源:watch_pages_tos_service.py

示例13: test_busy_check_on_teardown

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def test_busy_check_on_teardown():
    # max_workers needs to be provided, as it's used in a semaphore count
    config = {'max_workers': 4}
    kill_called = Mock()

    class MockedContainer(ServiceContainer):
        def kill(self):
            kill_called()
            super(MockedContainer, self).kill()

    sr = ServiceRunner(config, container_cls=MockedContainer)
    sr.add_service(ExampleService)
    sr.start()
    sr.kill()
    with wait_for_call(5, kill_called) as kill_called_waited:
        assert kill_called_waited.call_count == 1
開發者ID:ahmb,項目名稱:nameko,代碼行數:18,代碼來源:test_parallel.py

示例14: main

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
def main():

    logging.basicConfig(level=logging.DEBUG)

    # disable most logging so we can see the console
    logger = logging.getLogger("")
    logger.setLevel(logging.WARNING)

    config = {"AMQP_URI": "amqp://guest:[email protected]:5672/chat"}
    runner = ServiceRunner(config)
    runner.add_service(Chat)
    runner.start()
    try:
        runner.wait()
    except KeyboardInterrupt:
        runner.stop()
開發者ID:pbowyer,項目名稱:nameko-chat,代碼行數:18,代碼來源:service.py

示例15: handle

# 需要導入模塊: from nameko.runners import ServiceRunner [as 別名]
# 或者: from nameko.runners.ServiceRunner import add_service [as 別名]
    def handle(self, *args, **options):
        runner = ServiceRunner(settings.AMQP_CONFIG)
        runner.add_service(MasterService)

        def shutdown(signum, frame):
            eventlet.spawn_n(runner.kill)
        signal.signal(signal.SIGTERM, shutdown)

        runner.start()
        try:
            runner.wait()
        except KeyboardInterrupt:
            try:
                runner.stop()
            except KeyboardInterrupt:
                runner.kill()
開發者ID:amd77,項目名稱:parker,代碼行數:18,代碼來源:nameko_server_post.py


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