0

如果我启动服务器python wsserver.py,然后运行python wsclient.py --host localhost --port 8888龙卷风服务器,客户端会按预期运行。

但是,如果我也启动代理服务器:node node_modules/http-proxy/bin/node-http-proxy --port 8889 --host localhost --target localhost:8888thenpython wsclient.py --host localhost --port 8889确实连接,但没有消息传递。

这在 Max osx 上运行良好,但在 ubuntu 和 centos 上失败。

wsserver.py:

import tornado.httpserver
import tornado.websocket
import tornado.ioloop
import tornado.web

class WSHandler(tornado.websocket.WebSocketHandler):
  def open(self):
    print "opened a new websocket"
    listeners.append(self)
    print listeners

  def on_message(self, message):
     self.write_message(u"You Said: " + message)
     print ("in on_message " + message)

  def on_close(self):
    print 'connection closed'
    listeners.remove(self)


def main():
    application = tornado.web.Application([(r'/ws', WSHandler)])
    http_server = tornado.httpserver.HTTPServer(application)
    http_server.listen(8888)
    tornado.ioloop.IOLoop.instance().start()

if __name__ == "__main__":
    main()

wsclient.py:

# must pip install websocket-client first

from argparse import ArgumentParser

def main():
    parser = ArgumentParser()
    parser.add_argument('--port', type=int, required=True)
    parser.add_argument('--host', required=True)

    args = parser.parse_args()
    from websocket import create_connection
    ws = create_connection("ws://%s:%s/ws" %(args.host, args.port))
    print "Sending 'Hello, World'..."
    ws.send("Hello, World")
    print "Sent"
    print "Reeiving..."
    result =  ws.recv()
    print "Received '%s'" % result
    ws.close()

if __name__ == '__main__':
    main()

我该如何调试?

版本:

  • 节点:0.9.9
  • http代理;0.10.2
  • 蟒蛇:2.7
  • 龙卷风:2.4.1
4

1 回答 1

1

你可以用 node v0.6.x 试试吗?据我所知,node-http-proxy 与 websockets 有一些头问题,因为从来没有 node 版本(不确定它从哪个版本开始)。我确定使用较低的节点版本你应该没问题。

于 2013-04-27T20:46:00.690 回答