Как заставить подписчика спать, если в Google PUBSUB нет сообщений от издателя - PullRequest
0 голосов
/ 26 марта 2020

Я использую Google PubSub Publisher для запуска уведомления и отправки сообщения подписчику, когда документ загружен в Google Cloud Storage Bucket.

Я создал уведомление topi c by -> gsutil уведомления создать -t [TOPIC_NAME] -f json -e OBJECT_FINALIZE gs: // [BUCKET_NAME]

Функция моего подписчика: **

def callback(message):
    try:
        #storage_client = storage.Client.from_service_account_json('storage_service_key.json')
        print('Received message: {}'.format(message.data.decode("utf-8")))
        data = json.loads(message.data.decode("utf-8"))

        filename = data['name']
        file_name = re.search(r'/(.*)', filename).group(1)
        #filelink = data['selfLink']
        print("Processing the file : {}".format(file_name))
        path = "sample/"+file_name
        download_files(path, file_name)
        rming.image_remover(file_name) ## my custom function
        message.ack()
        os.remove(file_name)


    except Exception as error_message:
         print("Error in callback method: {}".format(error_message))
         pass


flow_control = pubsub_v1.types.FlowControl(max_messages=1)

subscriber = pubsub_v1.SubscriberClient()
subscription_path = subscriber.subscription_path(proj_name, sub_name)

streaming_pull_future = subscriber.subscribe(
    subscription_path, callback=callback,flow_control=flow_control
)
print('Listening for messages on: {}'.format(subscription_path))
with subscriber:
    try:
        # When `timeout` is not set, result() will block indefinitely,
        # unless an exception is encountered first.
        #flag=0
        streaming_pull_future.result()
    except Exception as error_message:  # noqa
        print("exception occured while handling subscription: {}").format(error_message)
        pass

** Я хочу развернуть эту функцию подписчика в контейнере docker. Затем он заставит подписчика работать 24/7.

Могу ли я перевести абонента в спящий режим / (не делать запрос на извлечение) в Publisher, когда нет доступных сообщений ИЛИ Мой смысл в другом термине - могу ли я сделать Абонент спит в простое, когда нет входящих сообщений.

Любая помощь приветствуется !!!!

1 Ответ

2 голосов
/ 27 марта 2020

Кроме того, и в резюме комментариев есть много вещей

Cloud Run масштабируется до 0, и вы можете использовать только время обработки, округленное до верхних 100 мс. Он не спит и ничего не стоит, когда нет сообщения.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...