使用 python 3.6 异步的 UDP 代理服务器

UDP Proxy server using python 3.6 async

我很好奇如何使用异步模块创建 UDP 代理服务器。我今天早些时候尝试使用 Twisted,但没有取得太大进展。我确实在 Whosebug 上找到了一些直接使用套接字的简单解决方案,但我想知道使用异步库是否可行。

为清楚起见,我要查找的是:

第 1 步:客户端 A(可以是多个)与代理 B 通话 第 2 步:代理 B 将请求连同服务器 C 一起发送。 第三步:服务器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 为每个连接创建一个新实例。我认为我需要为每个连接创建一个新实例,我相信,因为这样我就可以将原始地址存储在实例中,然后 return 那个。我认为这不适用于 create_datagram_endpoint,或者我不知道该怎么做。

虽然可能有更好的方法。

您需要服务器 B 的本地端点,以及每个客户端 A 到服务器 C 的远程端点。

这里是a possible implementation.

此外,您可能对 this module providing high-level UDP endpoints for asyncio.

感兴趣