cha*_*.ct 7 python sockets networking udp python-asyncio
我正在尝试在 python 异步循环中接收 UDP 数据包。我对 asyncio 很陌生,所以我可能做错了什么,因为回调永远不会被调用:
import asyncio
class DiscoveryProtocol(asyncio.DatagramProtocol):
def __init__(self):
super().__init__()
def connection_made(self, transport):
self.transport = transport
def datagram_received(self, data, addr):
print(data)
def start_discovery():
loop = asyncio.get_event_loop()
t = loop.create_datagram_endpoint(DiscoveryProtocol,local_addr=('',5006))
loop.run_until_complete(t)
loop.run_forever()
Run Code Online (Sandbox Code Playgroud)
我可以使用普通的旧套接字接收数据包(没有异步)。
我究竟做错了什么?
没有被接受的答案,所以这似乎已经萎缩,但它出现在搜索中。如果有人来到这里并想要最终的解决方案,下面的代码片段说明了一个功能齐全的 UDP 服务器。该write_messages()函数只是一个测试方法。它读取包含您想要的任何内容的日志文件,并将每一行作为 Syslog 消息发布到 UDP 端口 514。将其作为脚本运行说明服务器侦听并打印从 syslog 中排出的任何内容。SyslogProtocol使用您有的任何格式/处理需求更新。
import socket
import asyncio
import os, random
HOST, PORT = 'localhost', 514
def send_test_message(message: 'Message to send to UDP port 514') -> None:
sock = socket.socket(socket.AF_INET, # Internet
socket.SOCK_DGRAM) # UDP
sock.sendto(message.encode(), (HOST, PORT))
async def write_messages() -> "Continuously write messages to UDP port 514":
dir_path = os.path.dirname(os.path.realpath(__file__))
fp = open(os.path.join(dir_path, "tests/example.log"))
print("writing")
for line in fp.readlines():
await asyncio.sleep(random.uniform(0.1, 3.0))
send_test_message(line)
class SyslogProtocol(asyncio.DatagramProtocol):
def __init__(self):
super().__init__()
def connection_made(self, transport) -> "Used by asyncio":
self.transport = transport
def datagram_received(self, data, addr) -> "Main entrypoint for processing message":
# Here is where you would push message to whatever methods/classes you want.
print(f"Received Syslog message: {data}")
if __name__ == '__main__':
loop = asyncio.get_event_loop()
t = loop.create_datagram_endpoint(SyslogProtocol, local_addr=('0.0.0.0', PORT))
loop.run_until_complete(t) # Server starts listening
loop.run_until_complete(write_messages()) # Start writing messages (or running tests)
loop.run_forever()
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
15330 次 |
| 最近记录: |