我很想知道如何使用异步模块创建UDP代理服务器。我今天早些时候和Twisted一起尝试过,但没有取得多大进展。我确实在stackoverflow上直接使用套接字找到了一些简单的解决方案,但我想知道是否可以使用async lib。
为清楚起见,我正在寻找的是:
步骤1:客户A(可以很多)与代理B通话 步骤2:代理B将请求发送到服务器C. 步骤3:服务器C响应代理B 9月4日:代理B响应客户端A.
这是我到目前为止所拥有的:
import asyncio
class EchoServerProtocol(asyncio.DatagramProtocol):
def connection_made(self, transport):
self.transport = transport
def datagram_received(self, data, addr, args=None):
message = data
server_addr = ('localhost', 27015)
print('Received %r from %s' % (message, addr))
print('Send %r to %s' % (message, server_addr))
self.transport.sendto(data, server_addr)
loop = asyncio.get_event_loop()
print("Starting UDP server")
# One protocol instance will be created to serve all client requests
listen = loop.create_datagram_endpoint(
EchoServerProtocol,
local_addr=('0.0.0.0', 27016),
)
transport, protocol = loop.run_until_complete(listen)
try:
loop.run_forever()
except KeyboardInterrupt:
pass
transport.close()
loop.close()
以上基本上是这样的:
https://docs.python.org/3/library/asyncio-protocol.html#udp-echo-server-protocol
我所拥有的将会引导您进入第3步,但当然在步骤4中失败。它将其发送回服务器C.
您将注意到其他协议示例之一EchoServerClientProtocol
为每个连接创建一个新实例。我认为我需要为每个连接创建一个新实例,因为我可以将原始地址存储在实例中,然后返回。我认为这不适用于create_datagram_endpoint
,或者我无法弄清楚如何做到这一点。
虽然可能有更好的方法。
答案 0 :(得分:4)
您需要服务器B的本地端点,以及每个客户端A的服务器C的远程端点。
另外,您可能对this module providing high-level UDP endpoints for asyncio.
感兴趣