端口可能会动态变化
1
black11black 2020-04-04 15:07:02 +08:00
奇怪的需求,不知道原生有没有人做这种。aiohttp 有抽象 http 协议接口,你自己写重构逻辑层的话可以实现多监听。不想大动干戈的最简单方法是找一些业务的 tricky point,deamon 线程随着端口变化动态绑定服务端口。
|
2
ClericPy 2020-04-04 17:03:48 +08:00
丢给 upstream 那头 nginx 负责转发?
|
3
est 2020-04-04 17:51:16 +08:00 via Android
如果有别的语言的例子,抄一个
|
4
lithbitren 2020-04-04 19:34:38 +08:00 via iPhone
另写一个进程管理,多进程启动多个服务,不需要的服务可以直接把进程扬了。
|
5
cz5424 2020-04-04 19:39:18 +08:00
百度一下抓包软件的实现方法
|
6
SingeeKing 2020-04-04 19:54:43 +08:00
核心逻辑起一个项目 A,网络相关的起一个项目 B,再来一个项目 C 专门进行网络项目的启动管理。
然后网络相关的都转发到 A 进行,C 专门用来启动多个 B |
7
PPTX OP 我表述的有点问题,程序需要接收多个端口的 http 消息,且端口数量和端口号可能动态变化
|
8
PPTX OP @black11black 我表述的有点问题,程序需要接收多个端口的 http 消息,且端口数量和端口号可能动态变化
@cz5424 @ClericPy @lithbitren @SingeeKing @ClericPy @est |
9
chibupang 2020-04-04 22:27:02 +08:00 via iPhone
如果是 Java 可以通过 NIO Selector 注册事件来实现.....Python 打扰了....
|
10
NYGK 2020-04-04 22:58:23 +08:00
最直接的办法 multiprocessing 开多进程,每个进程监听一个;
如果需要需要变更端口监听可以创建新进程或者 kill 原有进程。这方法最直接但是有点蠢。 |
11
ipwx 2020-04-04 23:27:00 +08:00
上 aio 啊。所有 server socket 的 coroutine 把任务扔给 executor 不就行了。监听和执行分割开来就行了,以后你想上非 http 也易如反掌。
|
12
tempdban 2020-04-05 00:56:36 +08:00 via Android
raw socket
|
13
FINDNOMORE 2020-04-05 08:18:27 +08:00
如果只是验证的话,自己用 socket 套接字手动绑定接受就可以了
|
14
tairan2006 2020-04-05 11:26:43 +08:00 via Android
Go 的话很简单…python 你只能多进程了
|
15
black11black 2020-04-05 14:25:14 +08:00
@ipwx aiohttp 的 serve 默认阻塞的,相当于接管事件循环。你要从 socket 搭的话相当于重新实现 http 协议。
|
16
ipwx 2020-04-05 15:42:45 +08:00
@black11black asyncio 的 executor 支持线程池啊。aiohttp 接受到的请求,然后用 asyncio Queue 把 task 塞进去,阻塞的东西算完,然后再把结果在 http 的 coroutine 上通过 await 弄回来不久行了???整个过程不会阻塞 http 的事件循环。
|
17
julyclyde 2020-04-05 16:29:11 +08:00
基本上可以猜到是需求有问题
多开几个 listener 呗 |