原 荐 ActFramework 在 TEB

TechEmpower Benchmark 是业界公认的 web 框架/平台技术的PK场,刚刚发布的第14轮测试报告中比较了超过 140 中不同的语言/平台/框架技术,可以说这就是一个 Web 技术的嘉年华(Canival)。在第14轮中 TechEmpower 对所有的框架在同一个环境下实施了 6 种测试。这里我不打算罗列所有的 140 种技术,我将会比较所有 JVM 平台(包括 Java, Scala, Kotlin, Groovy 和 Closure) 上的全栈 Web 框架在本次性能测试中的结果:

非全栈框架或平台(比如 undertow, netty等) 不在下面的比较结果中

JSON Serialization 测试结果比较

数据来源: https://www.techempower.com/benchmarks/#section=data-r14&hw=ph&test=json&l=6nq2qj&c=6

ActFramework 在这个测试中以每秒 334,157 次的吞吐率排行第 4. 业界主流框架 Spring 的测试结果为每秒 22,228 次落在排行榜尾部

Single Query 测试结果比较

数据来源: https://www.techempower.com/benchmarks/#section=data-r14&hw=ph&test=db&l=6nq2qj&c=6

在这个测试中 ActFramework 派出了五名大将:

  • act-jdbc-pgsql (ActFramework 通过 RAW JDBC 访问 PostgreSQL 数据库): 每秒 77,650 次,排行第 5
  • actframework-pgsql (ActFramework 通过 BeetlSQL ORM 访问 PostgreSQL 数据库): 每秒 73,185
  • act-ebean-pgsql (ActFramework 通过 Ebean ORM 访问 PostgreSQL 数据库): 每秒 71,029
  • actframework-mongo (ActFramework 通过 Morphia 访问 MongoDB 数据库): 每秒 66,664
  • actframework-mysql (ActFramework 通过 Ebean ORM 访问 MySQL 数据库): 每秒 53,800
  • Spring (通过 Spring Data 访问 MySql 数据库): 每秒 16,204

Multiple Queries 测试结果比较

数据来源:https://www.techempower.com/benchmarks/#section=data-r14&hw=ph&test=query&l=6nq2qj&c=6

在这个测试中 act 和 PostgreSQL 的配合依旧十分出色,但 act 和 MySQL 的配合表现则不能让人满意:

  • act-jdbc-pgsql (ActFramework 通过 RAW JDBC 访问 PostgreSQL 数据库): 每秒 7,696 次,排行第 3
  • act-ebean-pgsql (ActFramework 通过 Ebean ORM 访问 PostgreSQL 数据库): 每秒 7,392
  • actframework-pgsql (ActFramework 通过 BeetlSQL ORM 访问 PostgreSQL 数据库): 每秒 7,135
  • actframework-mongo (ActFramework 通过 Morphia 访问 MongoDB 数据库): 每秒 4,618
  • Spring (通过 Spring Data 访问 MySql 数据库): 每秒 2,415
  • actframework-mysql (ActFramework 通过 Ebean ORM 访问 MySQL 数据库): 每秒 2,113

Fortunes 测试结果比较

数据来源:https://www.techempower.com/benchmarks/#section=data-r14&hw=ph&test=fortune&l=6nq2qj&c=6

  • act-jdbc-pgsql (ActFramework 通过 RAW JDBC 访问 PostgreSQL 数据库): 每秒 61,709 次,排行第 4
  • act-ebean-pgsql (ActFramework 通过 Ebean ORM 访问 PostgreSQL 数据库): 每秒 59,040
  • actframework-mysql (ActFramework 通过 Ebean ORM 访问 MySQL 数据库): 每秒 50,492
  • actframework-pgsql (ActFramework 通过 BeetlSQL ORM 访问 PostgreSQL 数据库): 每秒 33,163
  • actframework-mongo (ActFramework 通过 Morphia 访问 MongoDB 数据库): 每秒 25,720 次 (有点差强人意)
  • Spring (通过 Spring Data 访问 MySql 数据库): 每秒 24,047

Data Updates 测试结果比较

数据来源: https://www.techempower.com/benchmarks/#section=data-r14&hw=ph&test=update&l=6nq2qj&c=6

这个测试 PostgreSQL 依然坚挺, 而 MySQL 和 MongoDB 方面的表现都不理想

  • act-jdbc-pgsql (ActFramework 通过 RAW JDBC 访问 PostgreSQL 数据库): 每秒 1,978 次,排行第 2
  • actframework-pgsql (ActFramework 通过 BeetlSQL ORM 访问 PostgreSQL 数据库): 每秒 1,851
  • act-ebean-pgsql (ActFramework 通过 Ebean ORM 访问 PostgreSQL 数据库): 每秒 1,689
  • Spring (通过 Spring Data 访问 MySql 数据库): 每秒 897
  • actframework-mongo (ActFramework 通过 Morphia 访问 MongoDB 数据库): 每秒 633
  • actframework-mysql (ActFramework 通过 Ebean ORM 访问 MySQL 数据库): 每秒 432

Plaintext 测试结果比较

数据来源: https://www.techempower.com/benchmarks/#section=data-r14&hw=ph&test=plaintext&l=6nq2qj&c=6

和第一个 JSON 测试一样, Plaintext的测试不需要数据库, ActFramework 在这个测试中表现也不错, 每秒 601,390 次, 排名第 3. Spring 的成绩是每秒 128,577 次.

参考

所有参加 TechEmpower 测试的源代码都可以在 TechEmpower Benchmark 的 Github 项目 中找到.

关注 PHP

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java帮帮-微信公众号-技术文章全总结

Dubbo入门学习--Dubbo注册及监控中心(3)

Dubbo入门学习--Dubbo注册及监控中心 Dubbo提供广播、Zookeeper、Redis和Simple四种注册中心类型。 Multicast注册中心 ...

3173
来自专栏FreeBuf

远程遥控IPTables进行端口复用

有一天坐地铁的时候突然想到利用 iptables nat 表的 PREROUTING 链配合 REDIRECT 应该是可以达到端口复用的效果的。比如在服务器的 ...

2686
来自专栏熊二哥

Maven快速入门

Maven是Java中最为普及的包管理工具,在实际项目中由于依赖的各类jar包非常多,因此概念清晰的处理好各类Jar依赖显得非常重要,接下来通过基础知识,Jar...

4059
来自专栏YouMeek

使用 Github 空间搭建 Hexo 博客 2–增强篇

主题优化 主题配置介绍 我这里只讲自己在使用的 yelle 主题,你可以参考下,可能还有一些改动我后续会自己在慢慢改,但是大体基本也就这样了。 从中我们也可以看...

3337
来自专栏圆方圆学院精选

【戴嘉乐 IPFS】IPFS Desktop:IPFS节点桌面管理App

IPFS Desktop是一个由IPFS官方应用社区(IPFS-Shipyard)孵化出来的应用项目。 Ta是一个通过Node.js编写的桌面管理软件,比之前提...

671
来自专栏张戈的专栏

解决Nginx Helper插件一键清理缓存功能导致网站打不开问题

5 月份,张戈博客分享了一篇《Nginx 开启 fastcgi_cache 缓存加速,支持 html 伪静态页面》的文章。文中也提到了 WordPress 有一...

3569
来自专栏JackieZheng

没做过大项目,但我会建大项目

那时候使用着曾经宇宙最好用的JAVA IDE Eclipse写代码,也没有觉得界面简陋影响编码。

633
来自专栏nnngu

01 整合IDEA+Maven+SSM框架的高并发的商品秒杀项目之业务分析与DAO层

项目源代码:https://github.com/nnngu/nguSeckill ---- 这是一个整合IDEA+Maven+SSM框架的高并发的商品秒杀项...

3608
来自专栏张善友的专栏

SQL Server 2008多版本并发控制

数据库的一致性,也是衡量DBMS性能的重要指标之一。目前大多数商业数据库(DB2, SQL Server)的并发控制采用的是两阶段锁(Two-Phase Loc...

1876
来自专栏HaHack

化繁为简的企业级 Git 管理实战(二):多分支子模块持续集成

1432

扫码关注云+社区