【发布时间】:2023-03-07 01:43:01
【问题描述】:
有人可以帮助我使用 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'
即使没有发送任何消息,也会在短时间内(不到几分钟)后发生这种情况。一旦它崩溃了,就无法恢复 - 例如。通过按回车键、输入 quit()、按 CTRL+C 等,所以我必须关闭实例并重新开始。
我觉得有点奇怪,我如此密切地关注教程,但在我的代码运行时却出现了无提示的错误。请有人指出我出错的地方或建议一个强大的解决方法来忽略错误并继续收听消息吗?
向任何可以提供帮助的人致以诚挚的问候和感谢,
保罗
【问题讨论】:
标签: python gcloud google-cloud-pubsub