发现一个框架性能对比网站,我把 rust/go/ Java /csharp/js/py 对比了下
直接上 link: web-frameworks-benchmark.netlify.app/result?l=python,go,rust,java,javascript,csharp
这个网站好像定时会把流行框架最新版本拿来测试下性能,qps 之类的,上次测试刚好是昨天,时效性挺高。
对比了下发现
1 、js 的 uwebsockets 框架性能吊打其他框架( 20w qps ),不知道是咋做到的
2 、紧接着是 java 的框架,主要是 activej ,这个好像没啥人用,应该属于那种专精性能的,qps 19.9w 。
3 、然后就是 rust 的 actix 了,qps 19.5w
4 、再往下很大都是 java 系列的,什么 vertx (这个听说过)、rapidoid 、jooby ,JIT 优化确实强
5 、再往下就是 go 了,都说 go 性能一般,最好的是 fasthttp ,qps 在 17w 多,也不算差了,接着是 fiber 、gorouter ,还有字节的 hertz
6 、rust 的 axum 性能比 gin 好,但要比 go 的 fasthttp 、fiber 差
7 、接下来还是清一色的 go 框架,不得不吐槽 go web 框架是真的多,感觉都没啥区别。gin 、echo 在 12w qps
8 、不出意料的垫底:python ,django qps 居然只有 1.6k ,这也太差劲了……
9 、用的比较多的 spring 在 5w qps ,中游的样子,够用,并且生态比绝大部分框架都强
当然真实项目的性能肯定没这么简单,这只是单纯测试框架处理请求的能力而已,别太较真
确实不能太较真。。 拿 1.6k 的 django 来说,一个请求,框架本身占用的耗时才不到 1ms ,我在挂梯子访问 v 站的时候,所有请求耗时都至少 100ms 了。。
我列的是 256 个并发连接的 qps ,所以 1.6k 的 Django 实际一个请求要 6ms 差不多,这是没有业务逻辑的,比其他框架确实差很多🤣
uwebsockets 用 c 和 c++写的
js 套壳吗?好像 js 经常这么干
套了一层绑定,js 下面性能比较高的框架是套了一层 uwebsockets ,比较看好 hyper-express ,有性能的同时又有了 express 的部分生态
加上 PHP ,发现上了 swoole php 性能还是比 go 强
他 bench 的源码太简单了,和直接 accept tcp 应该没啥区别
go 最快的是 fasthttp , 可能是因为把路由写死了。。。 github.com/the-benchmarker/web-frameworks/blob/master/go/fasthttp/main.go
打一份而已,需要这样操心吗?软件不光是性能问题,更是性价比问题。
fasthttp 本就没有理由功能
有没有列出资源占用的对比?就是想看看付出的成本有多大
应该把 php 也加进来
workerman 排第七(#^.^#)
用的 Java 版本有点老
Python 的框架需要 wsgi, 这家伙是直接用框架自带的 wsgiref 来测的吧
www.techempower.com/benchmarks/#hw=ph&test=fortune§ion=data-r22
js/java 能排 c/c++/rust 前面,这网站不用看了
其他语言本来就是编译成 wasm 给 JavaScript 打工嘚,怎么就不用看了,不服气吗
测框架性能当然越简单越好
看这种网站和以上一些认知,我就不想说了, 你自己开心就好。
回 18 楼:这么说的话,shell 最牛逼,所有的程序,只要需要在 OS 上跑的,都得通过它调用,都是给它打工。 @.V.@
Java 能升级到 jdk21 并使用 zgc 和虚拟线程的话,性能应该会有点提升我的网关服务也升级后有稍微提升
这个数据有些诡异:吞吐=并发/平均响应时间但从数据上来看平均响应小的框架,QPS 反而不高。
go 的 fasthttp 算不上框架吧 只是一个路由
这玩意儿,看看就好,实际开发,接口一复杂,大家都一样了。比如一个接口 500ms ,框架本身是 10ms 还是 1ms 影响不是很大了。
打榜真没必要,开发体验大过一切。
有一定参考意义,像我这种啥都不懂的 java 农可以顺着找到不少好玩的东西但是实际项目开发,web 框架的性能,不说是最需要考虑的东西,但也可以说是最微不足道的东西了,一来十成甚至九成的性能瓶颈不在 web 层,二来在 web 层被打崩之前一般接入层就已经跑满了
techempower.com
PHP 不配吗
每几个月,就有这样一篇比较
公司有个项目,每秒接收大概 1700 万字节的数据,会分成六个波形图,要求客户端能维持 60 帧,目前公司前端只有 vue,调研了下好像用 vue 没办法做到 用 ffmpe…
github.com/torvalds/linux/tree/8bcab0346d4fcf21b97046eb44db8cf37ddd6da0 hey guys its me…
昨天在修 log4j 漏洞突然有一点疑问,请各位大佬解惑: 首先自己的服务是 maven 和 spring-boot 构建的,昨天先用 mvn dependency:tree …