Google Pubsub Python 客户端库订阅者随机崩溃

问题描述 投票:0回答:1

有人可以帮助我使用 Google Pubsub Python 客户端库吗?我正在密切关注 https://cloud.google.com/pubsub/docs/pull#pubsub-pull-messages-async-python 上的教程,似乎会出现无提示的错误。我有一个名为“sendmessage.py”的简单脚本,它发送一条附加随机数的文本消息,以便我可以区分消息。订阅者代码在单独的计算引擎实例上运行,如下所示:

from google.cloud import pubsub_v1

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

def listen_for_errors():

    subscriber = pubsub_v1.SubscriberClient()
    subscription_path = subscriber.subscription_path('<my-project-name-here>', 'test-subscription')

    subscription = subscriber.subscribe(subscription_path, callback=callback)

    try:
        subscription.future.result()
    except Exception as e:
        print(
            'Listening for messages on {} threw an Exception: {}.'.format( 'test-subscription', e))
        raise

附上在两个计算实例上运行的发送/接收的屏幕截图。 系统在第一分钟左右似乎工作正常,然后订阅者似乎出现以下错误消息:

Exception in thread Thread-ConsumeBidirectionalStream:
Traceback (most recent call last):
  File "/usr/lib/python2.7/threading.py", line 801, in __bootstrap_inner
    self.run()
  File "/usr/lib/python2.7/threading.py", line 754, in run
    self.__target(*self.__args, **self.__kwargs)
  File "/usr/local/lib/python2.7/dist-packages/google/cloud/pubsub_v1/subscribe
r/_consumer.py", line 363, in _blocking_consume
    request_generator, response_generator)
  File "/usr/local/lib/python2.7/dist-packages/google/cloud/pubsub_v1/subscribe
r/_consumer.py", line 275, in _stop_request_generator
    if not response_generator.done():
AttributeError: '_StreamingResponseIterator' object has no attribute 'done'

即使没有发送消息,这种情况也会在短时间内(不到几分钟)发生。一旦崩溃,就无法恢复 - 例如通过按 Enter 键、输入 quit()、按 CTRL+C 等,所以我必须关闭实例并重新开始。

我觉得有点奇怪,我如此严格地遵循教程,但在我的代码运行时却出现了无提示的错误。请有人指出我出错的地方或建议一个强大的解决方法来忽略错误并继续监听消息吗?

python gcloud google-cloud-pubsub
1个回答
4
投票

发布我的问题后不久,我尝试在自己的计算机上运行相同的脚本,发现它们非常稳定,这使我得出结论,问题出在计算引擎实例的设置方式上。

我原来的启动代码包括以下几行:

sudo apt-get update
sudo apt-get -yq install python-pip
sudo apt-get install python-dev
sudo pip install --upgrade google-cloud-storage
sudo pip install --upgrade google-cloud-pubsub

我想知道最后一行是否应该引用 pubsub_v1,但无论如何我将引导脚本代码更改为:

sudo apt-get update
sudo apt-get -yq install python-pip
sudo pip install --upgrade google-cloud

看来问题已经解决了。

© www.soinside.com 2019 - 2024. All rights reserved.