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


Python pubsub_v1.SubscriberClient方法代碼示例

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


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

示例1: list_subscriptions_in_project

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def list_subscriptions_in_project(project_id):
    """Lists all subscriptions in the current project."""
    # [START pubsub_list_subscriptions]
    from google.cloud import pubsub_v1

    # TODO(developer)
    # project_id = "your-project-id"

    subscriber = pubsub_v1.SubscriberClient()
    project_path = subscriber.project_path(project_id)

    # Wrap the subscriber in a 'with' block to automatically call close() to
    # close the underlying gRPC channel when done.
    with subscriber:
        for subscription in subscriber.list_subscriptions(project_path):
            print(subscription.name)
    # [END pubsub_list_subscriptions] 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:19,代碼來源:subscriber.py

示例2: create_subscription

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def create_subscription(project_id, topic_id, subscription_id):
    """Create a new pull subscription on the given topic."""
    # [START pubsub_create_pull_subscription]
    from google.cloud import pubsub_v1

    # TODO(developer)
    # project_id = "your-project-id"
    # topic_id = "your-topic-id"
    # subscription_id = "your-subscription-id"

    subscriber = pubsub_v1.SubscriberClient()
    topic_path = subscriber.topic_path(project_id, topic_id)
    subscription_path = subscriber.subscription_path(project_id, subscription_id)

    # Wrap the subscriber in a 'with' block to automatically call close() to
    # close the underlying gRPC channel when done.
    with subscriber:
        subscription = subscriber.create_subscription(subscription_path, topic_path)

    print("Subscription created: {}".format(subscription))
    # [END pubsub_create_pull_subscription] 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:23,代碼來源:subscriber.py

示例3: get_subscription_policy

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def get_subscription_policy(project, subscription_id):
    """Prints the IAM policy for the given subscription."""
    # [START pubsub_get_subscription_policy]
    from google.cloud import pubsub_v1

    # TODO(developer)
    # project_id = "your-project-id"
    # subscription_id = "your-subscription-id"

    client = pubsub_v1.SubscriberClient()
    subscription_path = client.subscription_path(project, subscription_id)

    policy = client.get_iam_policy(subscription_path)

    print("Policy for subscription {}:".format(subscription_path))
    for binding in policy.bindings:
        print("Role: {}, Members: {}".format(binding.role, binding.members))

    client.close()
    # [END pubsub_get_subscription_policy] 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:22,代碼來源:iam.py

示例4: poll_notifications

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def poll_notifications(project, subscription_name):
    """Polls a Cloud Pub/Sub subscription for new GCS events for display."""
    # [BEGIN poll_notifications]
    subscriber = pubsub_v1.SubscriberClient()
    subscription_path = subscriber.subscription_path(
        project, subscription_name
    )

    def callback(message):
        print("Received message:\n{}".format(summarize(message)))
        message.ack()

    subscriber.subscribe(subscription_path, callback=callback)

    # The subscriber is non-blocking, so we must keep the main thread from
    # exiting to allow it to process messages in the background.
    print("Listening for messages on {}".format(subscription_path))
    while True:
        time.sleep(60)
    # [END poll_notifications] 
開發者ID:GoogleCloudPlatform,項目名稱:python-docs-samples,代碼行數:22,代碼來源:notification_polling.py

示例5: receive_messages

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def receive_messages():
    """Receives messages from a pull subscription."""

    scopes = ['https://www.googleapis.com/auth/chat.bot']
    credentials, project_id = google.auth.default()
    credentials = credentials.with_scopes(scopes=scopes)
    chat = build('chat', 'v1', credentials=credentials)

    subscription_id = os.environ.get('SUBSCRIPTION_ID')
    subscriber = pubsub_v1.SubscriberClient()
    subscription_path = subscriber.subscription_path(
        project_id, subscription_id)

    def callback(message):
        logging.info('Received message: %s', message.data)

        event = json.loads(message.data)
        space_name = event['space']['name']

        # If the bot was removed, we don't need to return a response.
        if event['type'] == 'REMOVED_FROM_SPACE':
            logging.info('Bot removed rom space %s', space_name)
            return

        response = format_response(event)

        # Send the asynchronous response back to Hangouts Chat
        chat.spaces().messages().create(
            parent=space_name,
            body=response).execute()
        message.ack()

    subscriber.subscribe(subscription_path, callback=callback)
    logging.info('Listening for messages on %s', subscription_path)

    # Keep main thread from exiting while waiting for messages
    while True:
        time.sleep(60) 
開發者ID:gsuitedevs,項目名稱:hangouts-chat-samples,代碼行數:40,代碼來源:bot.py

示例6: __init__

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def __init__(self, gc_project_id=None, credentials=None, default_ack_deadline=None):

        if gc_project_id is None or credentials is None:
            creds, project = get_google_defaults()

        self._gc_project_id = gc_project_id or project
        self._ack_deadline = default_ack_deadline or DEFAULT_ACK_DEADLINE
        _credentials = credentials or creds

        if USE_EMULATOR:
            self._client = pubsub_v1.SubscriberClient()
        else:
            self._client = pubsub_v1.SubscriberClient(credentials=_credentials) 
開發者ID:mercadona,項目名稱:rele,代碼行數:15,代碼來源:client.py

示例7: consume

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def consume(self, subscription_name, callback, scheduler):
        """Begin listening to topic from the SubscriberClient.

        :param subscription_name: str Subscription name
        :param callback: Function which act on a topic message
        :param scheduler: `Thread pool-based scheduler.<https://googleapis.dev/python/pubsub/latest/subscriber/api/scheduler.html?highlight=threadscheduler#google.cloud.pubsub_v1.subscriber.scheduler.ThreadScheduler>`_  # noqa
        :return: `Future <https://googleapis.github.io/google-cloud-python/latest/pubsub/subscriber/api/futures.html>`_  # noqa
        """
        subscription_path = self._client.subscription_path(
            self._gc_project_id, subscription_name
        )
        return self._client.subscribe(
            subscription_path, callback=callback, scheduler=scheduler
        ) 
開發者ID:mercadona,項目名稱:rele,代碼行數:16,代碼來源:client.py

示例8: subscriber

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def subscriber():
    yield pubsub_v1.SubscriberClient() 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:4,代碼來源:system.py

示例9: test_exported_things

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def test_exported_things():
    assert pubsub.PublisherClient is pubsub_v1.PublisherClient
    assert pubsub.SubscriberClient is pubsub_v1.SubscriberClient
    assert pubsub.types is pubsub_v1.types 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:6,代碼來源:test_pubsub.py

示例10: subscriber_client

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def subscriber_client():
    subscriber_client = pubsub_v1.SubscriberClient()
    yield subscriber_client
    subscriber_client.close() 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:6,代碼來源:subscriber_test.py

示例11: sub

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def sub(project_id, subscription_id):
    """Receives messages from a Pub/Sub subscription."""
    # [START pubsub_quickstart_sub_client]
    # Initialize a Subscriber client
    subscriber_client = pubsub_v1.SubscriberClient()
    # [END pubsub_quickstart_sub_client]
    # Create a fully qualified identifier in the form of
    # `projects/{project_id}/subscriptions/{subscription_id}`
    subscription_path = subscriber_client.subscription_path(project_id, subscription_id)

    def callback(message):
        print(
            "Received message {} of message ID {}\n".format(message, message.message_id)
        )
        # Acknowledge the message. Unack'ed messages will be redelivered.
        message.ack()
        print("Acknowledged message {}\n".format(message.message_id))

    streaming_pull_future = subscriber_client.subscribe(
        subscription_path, callback=callback
    )
    print("Listening for messages on {}..\n".format(subscription_path))

    try:
        # Calling result() on StreamingPullFuture keeps the main thread from
        # exiting while messages get processed in the callbacks.
        streaming_pull_future.result()
    except:  # noqa
        streaming_pull_future.cancel()

    subscriber_client.close() 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:33,代碼來源:sub.py

示例12: create_push_subscription

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def create_push_subscription(project_id, topic_id, subscription_id, endpoint):
    """Create a new push subscription on the given topic."""
    # [START pubsub_create_push_subscription]
    from google.cloud import pubsub_v1

    # TODO(developer)
    # project_id = "your-project-id"
    # topic_id = "your-topic-id"
    # subscription_id = "your-subscription-id"
    # endpoint = "https://my-test-project.appspot.com/push"

    subscriber = pubsub_v1.SubscriberClient()
    topic_path = subscriber.topic_path(project_id, topic_id)
    subscription_path = subscriber.subscription_path(project_id, subscription_id)

    push_config = pubsub_v1.types.PushConfig(push_endpoint=endpoint)

    # Wrap the subscriber in a 'with' block to automatically call close() to
    # close the underlying gRPC channel when done.
    with subscriber:
        subscription = subscriber.create_subscription(
            subscription_path, topic_path, push_config
        )

    print("Push subscription created: {}".format(subscription))
    print("Endpoint for subscription is: {}".format(endpoint))
    # [END pubsub_create_push_subscription] 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:29,代碼來源:subscriber.py

示例13: update_push_subscription

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def update_push_subscription(project_id, topic_id, subscription_id, endpoint):
    """
    Updates an existing Pub/Sub subscription's push endpoint URL.
    Note that certain properties of a subscription, such as
    its topic, are not modifiable.
    """
    # [START pubsub_update_push_configuration]
    from google.cloud import pubsub_v1

    # TODO(developer)
    # project_id = "your-project-id"
    # topic_id = "your-topic-id"
    # subscription_id = "your-subscription-id"
    # endpoint = "https://my-test-project.appspot.com/push"

    subscriber = pubsub_v1.SubscriberClient()
    subscription_path = subscriber.subscription_path(project_id, subscription_id)

    push_config = pubsub_v1.types.PushConfig(push_endpoint=endpoint)

    subscription = pubsub_v1.types.Subscription(
        name=subscription_path, topic=topic_id, push_config=push_config
    )

    update_mask = {"paths": {"push_config"}}

    # Wrap the subscriber in a 'with' block to automatically call close() to
    # close the underlying gRPC channel when done.
    with subscriber:
        result = subscriber.update_subscription(subscription, update_mask)

    print("Subscription updated: {}".format(subscription_path))
    print("New endpoint for subscription is: {}".format(result.push_config))
    # [END pubsub_update_push_configuration] 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:36,代碼來源:subscriber.py

示例14: receive_messages

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def receive_messages(project_id, subscription_id, timeout=None):
    """Receives messages from a pull subscription."""
    # [START pubsub_subscriber_async_pull]
    # [START pubsub_quickstart_subscriber]
    from concurrent.futures import TimeoutError
    from google.cloud import pubsub_v1

    # TODO(developer)
    # project_id = "your-project-id"
    # subscription_id = "your-subscription-id"
    # Number of seconds the subscriber should listen for messages
    # timeout = 5.0

    subscriber = pubsub_v1.SubscriberClient()
    # The `subscription_path` method creates a fully qualified identifier
    # in the form `projects/{project_id}/subscriptions/{subscription_id}`
    subscription_path = subscriber.subscription_path(project_id, subscription_id)

    def callback(message):
        print("Received message: {}".format(message))
        message.ack()

    streaming_pull_future = subscriber.subscribe(subscription_path, callback=callback)
    print("Listening for messages on {}..\n".format(subscription_path))

    # Wrap subscriber in a 'with' block to automatically call close() when done.
    with subscriber:
        try:
            # When `timeout` is not set, result() will block indefinitely,
            # unless an exception is encountered first.
            streaming_pull_future.result(timeout=timeout)
        except TimeoutError:
            streaming_pull_future.cancel()
    # [END pubsub_subscriber_async_pull]
    # [END pubsub_quickstart_subscriber] 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:37,代碼來源:subscriber.py

示例15: receive_messages_with_custom_attributes

# 需要導入模塊: from google.cloud import pubsub_v1 [as 別名]
# 或者: from google.cloud.pubsub_v1 import SubscriberClient [as 別名]
def receive_messages_with_custom_attributes(project_id, subscription_id, timeout=None):
    """Receives messages from a pull subscription."""
    # [START pubsub_subscriber_async_pull_custom_attributes]
    from concurrent.futures import TimeoutError
    from google.cloud import pubsub_v1

    # TODO(developer)
    # project_id = "your-project-id"
    # subscription_id = "your-subscription-id"
    # Number of seconds the subscriber should listen for messages
    # timeout = 5.0

    subscriber = pubsub_v1.SubscriberClient()
    subscription_path = subscriber.subscription_path(project_id, subscription_id)

    def callback(message):
        print("Received message: {}".format(message.data))
        if message.attributes:
            print("Attributes:")
            for key in message.attributes:
                value = message.attributes.get(key)
                print("{}: {}".format(key, value))
        message.ack()

    streaming_pull_future = subscriber.subscribe(subscription_path, callback=callback)
    print("Listening for messages on {}..\n".format(subscription_path))

    # Wrap subscriber in a 'with' block to automatically call close() when done.
    with subscriber:
        try:
            # When `timeout` is not set, result() will block indefinitely,
            # unless an exception is encountered first.
            streaming_pull_future.result(timeout=timeout)
        except TimeoutError:
            streaming_pull_future.cancel()
    # [END pubsub_subscriber_async_pull_custom_attributes] 
開發者ID:googleapis,項目名稱:python-pubsub,代碼行數:38,代碼來源:subscriber.py


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