
端口可能会动态变化
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 PRO 核心逻辑起一个项目 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 呗 |