
一个项目有 http 服务和底层的 tcp 服务,想过用 spring boot 启动后异步启动 netty,但是有人建议一个进程最好不要挂两个服务端程序。如果技术菜,netty 内存管理处理不好,就容易死掉。
那有没有一个封装好的网络服务框架,既能处理 http 服务,又能处理 tcp 服务处理,处理策略像 netty 可以设置两个 handler,一个无处理,可以交给下一个处理。如果侦测到是 http 请求就交给 http 处理,如果不是,就交给底层的 tcp 处理器处理
当然解决方式,除了把 http 和 tcp 处理挂在一个程序,还有一个方式,把一个进程服务拆分两个进程服务。但这种要面临进程服务管理上的问题
netty 自带 HttpObjectAggregator,我没用过,有用过的么,加了这个,如果还得要添加自定义 tcp 处理的话,会有什么问题么,除了 netty,还有其他的方式么?比如 vert.x 那个?那个有谁用过么?
1 wysnylc May 11, 2020 socket 吧 |
2 diggzhang May 11, 2020 akka-http? |
3 est May 11, 2020 没有。 |
4 catror May 11, 2020 via Android 用 websocket 不就好了? |
6 heiybb May 11, 2020 |
7 donyee May 11, 2020 你这是同一个端口处理请求的吗? vertx 封装了 http tcp 模块的,http 部分比较好用,tcp 部分未使用过 |
9 Kakajing May 11, 2020 NettyOne framework master all Framework |
10 guixiexiezou May 11, 2020 我猜楼主估计是想同时监听 tcp,同时又想要的 http 回调吧。一般 java 游戏服务端的操作是:用 netty 处理普通 tcp,嵌入一个 tomcat 或者 jetty ( sparkjava 是最简单了的方式了)处理 http...既简单又高效 |
11 catror May 11, 2020 via Android @tctc4869 可以,websocket 哪都能用。看你项目原始需求是啥,如果只是需要一条长链接数据通道,我觉得用 websocket 是最简单的。 |
12 horsea May 12, 2020 我也有这个疑问,有请游戏开发行业的人解答下,游戏 websocket 用 netty,http 用什么框架集成呢? |
13 luozic May 12, 2020 via iPhone vertx 底层就是 netty,不少 Java 框架都是用 netty 做底层,按你的需求,找个支持得框架去抄代码。 |
14 Malthael May 12, 2020 我用的就是 spring boot + netty 处理 http 、tcp 、websocket 啥的,挺好的啊。 |
15 ffLoveJava May 12, 2020 @Malthael 请问只用 netty 一个端口就能都相应 http 、tcp 、websocket 吗? 不用再用 tomcat 吗 |
16 Malthael May 12, 2020 @ffLoveJava #15 不能,我都是分端口处理的 |
17 tctc4869 OP @Malthael 我害怕的是我 netty 内存管理技术菜,导致内存管理处理不好,致使 http 或 tcp 服务死掉,因为我遇到过,不过不是 tomcat+netty,而是 undertow+netty 做一个服务端信息中转站,有几次出现进程服务不能正常使用,只能关闭重启再来,后来把 undertow 的 http 服务和 netty 服务拆成两个进程服务,挂了很多天这个问题就没有了。 |
18 zyxcompany May 12, 2020 frp |
19 enrio May 12, 2020 @tctc4869 websocket 也是可以的。不要把它想得就一定要在浏览器上跑,它归根到底也只是一个应用层协议。我就用过 Java 的 websocket 客户端。 |
20 javapythongo May 12, 2020 sprongboot + netty |
21 zoharSoul May 12, 2020 netty vertx |
22 dogfeet May 12, 2020 akka-stream,前面 gateway 将 tcp,http,websocket 消息统一转换成内部消息。 剩下的就是一致的消息进入到流中统一处理。后期换可以方便的扩展成集群模式。 |
25 Malthael May 12, 2020 |
26 cs419 May 12, 2020 如果你写多线程 别人提醒你可能有死锁的问题 你想着要不我用多进程吧 那担心是多余的 这说明你都没用上锁 那也就不会出现死锁 用 netty 怕遇上内存泄漏的话 多虑了 你应该还没用上 内存直接访问的 api 你担心内存管理的不好 程序挂掉 那你换个框架 该挂还是挂 服务拆成两个 java 进程就不挂掉 并不能说明就是 netty 的内存处理不当 或许 你一个 java 进程 但 http tcp 各用一个端口 也不会挂掉 |
27 yamasa Jun 24, 2020 迷惑行为。我们这儿一个很重要的微服务一直都是 boot+netty 开两个端口,正式上线之后从来没有过内存问题。netty 内存能出问题无非就是直接内存未正确释放这一类呗,我还巴不得我遇到过几次,彻底定位长长见识,以后出去面试还能吹水呢哈哈。 |