java zmq消息通信_将websocket请求桥接到ZMQ并返回

我创建了一个带有 ws4py 的Web套接字服务器,它将消息分派给ZMQ消息总线并将响应返回给Web套接字 . 精简代码如下所示:

from multiprocessing import Process

from gevent import monkey; monkey.patch_all()

from ws4py.websocket import WebSocket

from ws4py.server.geventserver import WSGIServer

from ws4py.server.wsgiutils import WebSocketWSGIApplication

import time

import gevent

from zmq.green.eventloop import ioloop, zmqstream

import zmq.green as zmq

class MyWebSocket(WebSocket):

def __init__(self, *args, **kwargs):

super(MyWebSocket, self).__init__(*args, **kwargs)

uri = 'tcp://127.0.0.1:5560'

context = zmq.Context()

self.publisher = context.socket(zmq.PUB)

self.publisher.bind(uri)

subscriber = context.socket(zmq.SUB)

subscriber.connect(uri)

subscriber.setsockopt(zmq.SUBSCRIBE, '')

loop = ioloop.IOLoop()

zstream = zmqstream.ZMQStream(subscriber, loop)

def _recv_result(msg):

print 'received from publisher', msg

zstream.on_recv(_recv_result)

gevent.spawn(loop.start)

def received_message(self, message):

# incoming from web client.

data = message.data

self.publisher.send_multipart(['id', data])

if __name__ == '__main__':

host, port = 'localhost', 9000

server = WSGIServer(

(host, port), WebSocketWSGIApplication(handler_cls=MyWebSocket)

)

server.serve_forever()

在这个最小的例子中,我删除了系统的处理部分,它将结果发送回消息总线并直接订阅消息(实际上使它成为一个复杂的echo服务器) . 问题是永远不会调用 _recv_result() . 我删除了所有订阅过滤器前缀,并使其成为 gevent 线程,但这没有帮助 . 有谁知道什么可能是错的?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值