有谁的公司已经用 WebFlux 替换了 SpringMVC 吗

113 天前
 DanLi

使用效果怎么样?性能有没有提升很多

新项目用还是花大功夫替换了旧业务代码

还是只有某一部分用,比如网关用,业务模块不用

4651 次点击
所在节点    Java
32 条回复
TWorldIsNButThis
113 天前
?那为什么不直接用 java21 ?
Java 的现任 leader 都说了将会杀死 reactive programming 了
kk2syc
113 天前
java 目前最现实的问题就是:想切换想更新的企业没有预算,有预算的企业不想切换不想升级
holulu
113 天前
用 webflux 超过 3 年了。性能有没有提升不知道,因为是新项目,没有对比。但反应式编程对程序员要求比较高,特别是面对复杂业务逻辑的时候。就跟习惯了命令式编程之后再转函数式编程那样,是思维模式的转换。
chendy
113 天前
尝试过,最后放弃,投入产出比过于低
reactor 这套东西,或者说所有类似的东西,主要是高并发下的资源占用少很多,也就是说,如果 存在高并发 且 希望减少资源使用 的情况下可以尝试,否则完全没有用的必要
另外的问题是,不能用同步语法写的异步都是 xx ,业务逻辑本就盘根错节,再来这么一层 Mono 和 Flux 真的就要命了
系统压力太大扛不住大不了可以加机器,神仙代码出问题找不到神仙解决那是真难受,不是神仙非要学神仙写神仙代码最后一对问题解决不了那是真 xx
sagaxu
113 天前
在 WebFlux ,Vert.x ,Quarkus 三个响应式框架中做过选择,最终选择了 Vert.x 。

三个都有回调地域的心智负担,当循环+分支+递归时,响应式写法要炸,WebFlux 还是这三个里性能最弱鸡的。

Quarkus 很好,但美中不足的是不支持 reproducible builds ,官方也很不以为意,四五年不解决,所以也放弃了
https://github.com/quarkusio/quarkus/issues/676

Vert.x 非常符合要求,高性能 + 框架简单 + 支持 native image + 支持 Java virtual threads + 支持 Kotlin Coroutine ,为了方便协程式同步写法,早年折腾出 vertx-sync ,后来用上了 quasar ,在 Kotlin 和 Java 的协程出来后也是立马就支持了。
Ayanokouji
113 天前
我赞同 1 楼,别研究了 WebFlux ,Virtual Threads 杀死了比赛
ccw4wcc
113 天前
用 webflux 开发了网关,性能不知道,但是代码是真的难维护,很看个人的功力,如果业务比较复杂的话,感觉应该挺困难用这个开发的
seedhk
113 天前
没有熟悉这块的大佬,不建议重新搞,更不建议上生产环境。这玩意不熟悉的话属于是明知道有 BUG ,明知道哪里问题,但是就是不知道怎么修。
cheng6563
113 天前
除非你业务真的就是异步的,比如游戏服务器,不然别弄啥反应式。
单纯为了性能,你不如重新学 go 用 go 搞还简单些,更别说现在有 Java21 了。
ccw4wcc
113 天前
每一个环节都需要异步,不然的话都会拖垮性能,每个中间件都得支持异步,服务端需要异步,客户端也需要异步
spritecn
113 天前
@holulu 不怕招不到人么?
chocotan
113 天前
不要用,问题太多
最严重的是各种场景下会发生内存泄露,最新版也无法解决
v2orz
113 天前
我们做网关用了几年了,让我重新选,我会选择不用
问题跟上面的兄弟说的一样:
1 )投入产出低,不能用同步语法写,业务逻辑多了之后要命。减少资源这一特点对于大一点的公司来说并不很重要;
2 )内存泄漏,github 上有个 issue 是我们团队提的,好多年了,我们自己没找到原因(缓解了),维护者也没找到
YIERIC
112 天前
@v2orz 能分享一下内存泄露的问题吗?现在已经小范围在用了,主要使用场景还在 SSE ,希望能取一些经,避免踩坑。或者能给个 issue 地址吗
967182
112 天前
@v2orz 真是,用了新版的 spring cloud gateway 强制升级版本以后真是套娃套的脑袋疼。
chronos
112 天前
以前用 webflux 改造过网关,写了一版后觉得收益太差又用回原来的了。webflux 维护麻烦,性能在我那个场景下也没优势。
xiaomushen
112 天前
1 不存在传说中的性能收益,尤其是针对 DB CRUD 的应用
2 写法不直观,耗费心智,debug 困难
3 居然还有新人关注?
lancelock
112 天前
别用,不如升级 jdk
flmn
112 天前
如果真有使用 WebFlux 的需求,还不如试一试 Go 呢,因为 java 生态本就是同步的,硬上 WebFlux 很难受,对开发者的要求也高。Go 生来就把异步做到了语言里,三方库天然支持。

如果没有那么大的压力,纯粹 MVC 用腻了想提升一下,那大可不必。

你再等个几年,同步的写法性能也上来了( Java 21 )。
yty2012g
112 天前
我是用来做数据上报的采集服务。目前使用的是 vertx 和 jdk23 ,整体来说:
1 、jdk21 (最好 >= 23 )+ SpringBoot 3.x + Virtual Thread ,大概是 85%~ 90% 左右的性能,但是相比较原来的写法,几乎没变化
2 、复杂业务可能还是得等 vt+structured Concurrency + Scoped Value 这套完全体,估计 jdk 25+应该有希望
3 、vert.x 性能还是相当 OK 的,因为我的业务逻辑相对简单,所以使用起来,性能确实比 vt 要好点。但如果之前是 springboot 那套,还是得改不少东西

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1090351

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX