使用 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 的远程端点。
此外,您可能对 this module providing high-level UDP endpoints for asyncio.
感兴趣
我很好奇如何使用异步模块创建 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 的远程端点。
此外,您可能对 this module providing high-level UDP endpoints for asyncio.
感兴趣