为了将数据发送到NATS (nats.io消息传递系统),我尝试使用coroutine。
当我试图不带参数地调用这段代码时,对于循环,它工作得很好。
但是,当我添加参数时,产生的nc.connect函数不会返回任何内容并继续主函数。
我怎么能称任何有争论的协同线?
@tornado.gen.coroutine
def process_events_list(events):
try:
nc = NATS()
parser = SafeConfigParser()
conf = os.path.realpath(
os.path.join(os.getcwd(),'ev_nats\\ev_nats.ini'))
parser.read(conf)
endpoints = ast.literal_eval(parser.get('Nats', 'Servers'))
subject = parser.get('Nats', 'Subject')
opts = {"servers": endpoints}
**yield nc.connect(**opts)** # wont connect return to main
for ev in events:
yield nc.publish(subject, ev)
yield nc.flush()
log("Published")
except Exception, e:
log(e)
if __name__=='__main__': # if run directly, not called by event_dispatcher.py
evt = ['1','2','3']
tornado.ioloop.IOLoop.instance().run_sync(lambda : process_events_list(evt))发布于 2017-07-31 10:15:13
我将进一步调试要传递给服务器的端点列表是否有效。否则,如果您可以连接到服务器,就应该这样做。
# coding: utf-8
import tornado.ioloop
import tornado.gen
from nats.io.client import Client as NATS
@tornado.gen.coroutine
def main(events):
print("Args:", events)
nc = NATS()
# Establish connection to the server.
options = { "servers": ["nats://127.0.0.1:4222"] }
yield nc.connect(**options)
for e in events:
yield nc.publish("example", "event:{}".format(e))
if __name__ == '__main__':
events = ['1', '2', '8']
tornado.ioloop.IOLoop.instance().run_sync(lambda: main(events))https://stackoverflow.com/questions/45400234
复制相似问题