V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
tairan2006
V2EX  ›  Java

支持虚拟线程的 TCP 服务框架?

  •  
  •   tairan2006 · 52 天前 · 2072 次点击
    这是一个创建于 52 天前的主题,其中的信息可能已经有所发展或是发生改变。

    Java 21 发布一年了,http 、websocket 、grpc 对虚拟线程支持的框架都有了。但是 netty 官方明确表示为了兼容 java11 ,不会支持虚拟线程( https://github.com/netty/netty/issues/12816 )。

    所以现在想用虚拟线程写个 tcp 服务,只能用 jdk 自带的库了么?有没有好写一点的框架。

    9 条回复    2024-11-28 11:14:38 +08:00
    codingmiao
        1
    codingmiao  
       52 天前   ❤️ 1
    虽然 netty 不会去全盘的换虚拟线程,但是 EventLoopGroup 可以自定义一个 ThreadFactory 在里面起虚拟线程,然后 channelRead0 里面如果有耗时操作也起一个虚拟线程去搞就行了,我是这么干的:
    https://github.com/codingmiao/hppt/blob/main/run/src/main/java/org/wowtools/hppt/common/util/NettyObjectBuilder.java

    然后我觉得虚拟线程整个体系还在起步阶段,比如 WebFlux 对比虚拟线程加持的 springboot 还是有一点点性能优势的,虚拟线程对比现有的响应式写法最大的优势是在性能没有拉下太多的前提下大幅降低了开发难度。jdk 官方也说了会逐步干掉响应式编程,或许到下一个 LTS 版本,netty 看环境成熟了也会走虚拟线程的。
    chandlerbing9317
        2
    chandlerbing9317  
       52 天前   ❤️ 1
    建议 netty 的提供的 eventLoop 线程只做 cpu 操作,如编解码,指令匹配等,一些业务操作还是要放在自定义线程池中,不要阻塞 eventloop 线程,而自定义的业务线程池可以使用虚拟线程。
    sujin190
        3
    sujin190  
       52 天前   ❤️ 1
    netty 支持虚拟线程有啥实际意义,虚拟线程协程之类的最大意义本来就是在用同步语法写异步逻辑,netty 就不可能再改回来变成同步语法否则也就不是 netty 了,还不说虚拟线程在线程上又多了一层调度器除了白白损失性能对 netty 意义不大吧,netty 的 Handler 本来就不应该有同步 io 操作,否则用 netty 这麻烦的说不是对此一举,有需要同步 io 操作本来就应该放到独立 executor 中去,这独立 executor 完全就可以是虚拟线程的啊
    mmdsun
        4
    mmdsun  
       52 天前
    @codingmiao 请问 JDK 官方逐步干掉响应式编程的说法有处出来源吗?
    BBCCBB
        5
    BBCCBB  
       52 天前
    eventloop 性能始终比有栈协程来的高, 只是 eventloop 相比协程来说写起来更麻烦, 以及有 callback..
    tairan2006
        7
    tairan2006  
    OP
       52 天前
    @codingmiao 所以,推荐 boss group 还是用系统线程,worker group 改成虚拟线程池?
    8675bc86
        8
    8675bc86  
       51 天前
    看到虚拟线程进来的,JAVA 就是会造词汇,coroutine 对吧。
    tairan2006
        9
    tairan2006  
    OP
       51 天前
    @8675bc86 是的
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2976 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 07:54 · PVG 15:54 · LAX 23:54 · JFK 02:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.