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

时间:2018-03-18 11:55:44

标签: python gcloud google-cloud-pubsub

有人可以帮我使用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

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

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 等,所以我必须关闭实例并重新开始。

我觉得有点奇怪,我正在密切关注这些教程,但是当我的代码运行时会出现无提示错误。请有人指出我出错的地方或建议一个强大的解决方法来忽略错误并继续收听消息吗?

亲切的问候并感谢任何可以提供帮助的人,

1 个答案:

答案 0 :(得分:3)

我开始养成回答我自己的问题的习惯(这可能意味着我应该在发布之前进行更多研究或尝试更努力!),但我相信我已经解决了上述问题。我想我会在这里发布答案以防其他人好奇或遇到同样的问题,但如果主持人更愿意删除主题,那么请这样做。

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

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

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,但无论如何我将bootscript代码更改为:

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

它似乎解决了这个问题。