如何解决Python Websocket服务器客户端PubSub
-
我正在从网站获取WebSocket数据,代码以
python
编写,并使用autobahn
,twisted
,threading
进行WebSocket处理。ws.subscribe(<list>)
用于订阅不同的项目,ws.unsubscribe(<list>)
用于使用on_message()
取消订阅和显示数据。 -
我想创建一个本地服务器,该服务器将服务于第1步中获得的数据(我希望是中继服务器)。我在想的流程:
a。本地客户端将请求订阅本地服务器。
b。本地服务器根据从本地客户端收到的订阅/取消订阅请求,将订阅实际服务器(步骤1)。
c。每当从实际服务器收到任何消息时,本地服务器都会根据订阅向本地客户端发送数据。
第1步代码:
from MainServer import MainDataService
mds = MainDataService(
user_id='user_id',apikey='APIKEY')
)
def on_connect(ws,response):
# settings subscribed,need to change based on local subscribe request
ws.subscribe(['demand'])
def on_message(ws,payload,is_binary):
# getting the message here,that need to relay based on local subscribe
if is_binary:
print(_parse_binary(payload))
else:
print(_parse_text_message(payload))
mds.on_connect = on_connect
mds.on_message = on_message
mds.connect(threaded=True)
如何实现这一点,使用什么?任何指南/代码都会有所帮助。
编辑1:这可能与crossbar.io,PUB / SUB,中继,WAMP,路由器有关。
编辑2:我做了什么:
启动纵横制路由器:crossbar init
,crossbar start
。
pub.py
from autobahn.asyncio.component import Component
from asyncio import sleep
from autobahn.asyncio.component import run
component = Component(
transports=u"ws://localhost:8080/ws",realm=u"realm1",)
@component.on_join
async def joined(session,details):
print("session ready")
counter = 0
while True:
session.publish(u'com.myapp.oncounter',counter)
counter += 1
await sleep(1)
if __name__ == "__main__":
run([component])
sub.py
from autobahn.asyncio.component import Component
from autobahn.asyncio.component import run
component = Component(
transports=u"ws://localhost:8080/ws",)
@component.subscribe(u"com.myapp.oncounter")
def oncounter(count):
print("event received: {0}",count)
if __name__ == "__main__":
run([component])
pub.py
和sub.py
正常运行。但是,我需要动态编码session.publish
,如“步骤2”中所述。这意味着只有subscribe
至demand
或oncounter
的任何客户端才发布。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。