Nic*_*ick 1 javascript python multiprocessing zeromq
我正在尝试让 ZeroMQ 在我的网络应用程序中工作。在前端,我使用的是 JSZMQ 库,它应该在浏览器中工作(我知道大多数库都不能)。在Python后端,我使用zmq。问题是我尝试的所有协议都会抛出错误。如果我尝试 TCP,正如预期的那样,浏览器会抛出一个错误,指出“不支持的传输”。
根据这个SO问题,当协议为“ws://”时,JSZMQ应该工作。当我尝试此操作时,服务器在运行时立即抛出“协议不支持”错误。这是我的代码:
客户:
import * as zmq from 'jszmq'
const socket = new zmq.Pull()
socket.connect('ws://127.0.0.1:3000')
socket.on('message', msg => console.log(msg))
Run Code Online (Sandbox Code Playgroud)
服务器:
import zmq
context = zmq.Context()
sock = context.socket(zmq.PUSH)
sock.bind('ws://127.0.0.1:3000') # This is what throws the error
sock.send('hello')
Run Code Online (Sandbox Code Playgroud)
如果重要的话,我正在为服务器进行多重处理,并将 zmq 对象作为全局对象,因为它不可序列化,并且无法作为参数传递到函数中。
为什么这不起作用?
你在这里有点困惑:
ws:// means http:// or default port 80
wss:// means https:// or default port 443
ws://<server>:<port> means http over that port.
Run Code Online (Sandbox Code Playgroud)
后台发生的事情是浏览器通过 http(s) 协议连接到服务器,并在可能的情况下将连接升级到 websocket。
浏览器不允许原始套接字连接,但允许Websocket连接。
看看https://github.com/zeromq/jszmq#compatibility-with-zeromq:
与 ZeroMQ 的兼容性
最近将 WebSocket 传输添加到 Zeromq,并且仅在从源代码编译时才可用。
Zeromq 的其他端口,例如 NetMQ (C#) 和 JeroMQ (Java) 尚不支持 WebSocket 传输。
您必须查看FastAPI Python 框架。
您正在寻找的模式是:
[SOCKET CLIENT] --> [FASTAPI SERVER] <--> [ZEROMQ]
Run Code Online (Sandbox Code Playgroud)
本文档展示了如何在单个文件中设置客户端 websocket 和 FastAPI 服务器: https://fastapi.tiangolo.com/advanced/websockets/
您的工作将在 websocket.receive_text 和 websocket.send_text 之间完成。
@app.websocket("/ws")
async def websocket_endpoint(websocket: WebSocket):
await websocket.accept()
while True:
data = await websocket.receive_text()
# --> ZeroMQ Code Here <--
await websocket.send_text(f"Message text was: {data}")
Run Code Online (Sandbox Code Playgroud)
这个框架非常棒,您可以充分利用本机后台任务: https: //fastapi.tiangolo.com/tutorial/background-tasks/
因此,您可以接受来自客户端的消息,并在某些 ZeroMQ 工作人员完成后发送回来。
还有很多有用的功能,例如异步数据库、即时 OpenAPI 文档等。