NodeJS、Java和PHP性能考量和若干参考结论
首先需要说明的是,严格而言NodeJS和Java、PHP并非对等概念,NodeJS是基于JS的一个应用程序,而Java/PHP是语言。
我们这里实际指的是分别使用node、java和php来实现一个网页应用,在这样的相等用例下,各自的性能表现。
自从2013年Paypal应用迁移到Node后,NodeJS被越来越多的巨头所使用。
这里面当然不只是技术层面的考虑,还有商业层面的考虑,因为Java规范实际上是由Oracle(Sun)所控制,而大公司显然不愿意把自己的核心平台全部建立在一个随时有可能收取授权使用费用的平台上。
撇开这个不谈,本文简要分析下这3个体系关乎性能的核心架构和概念。
Node架构
Node是一种异步单线程模式,所谓单线程指的是相对于Java而言,
实际上Node是单个主线程加上一堆工作线程,主线程负责接收请求,派遣任务和处理输出回调:
异步模式的好处,显然是具有更好的交互响应度,缺点是需要更高的管理成本。
如果你在超市只买了一瓶饮料,而前面的人买了一堆家用品,你必须等前面的人10分钟处理完成后,才花1分钟处理你的购买。
那么你就能明白异步模式的好处。异步模式相当于在收银员前面加了个管理员,然后收银员点好商品按先后次序通知管理员。
此外NodeJS借助Node Cluster库也可以实现多进程。
Java架构
Java网页应用是多线程模式(可以是阻塞式也可以是非阻塞式),多线程的好处是共享内存,坏处是可能会产生死锁。
对于性能而言,理论上采用非阻塞式模式时,其性能应该和Node相仿,能否更快就取决于各自JIT编译器的效率以及Web应用服务器的实现是否引入了额外的消耗。
PHP架构
为了追求简单,PHP是多进程(单线程)同步模式的,每个进程处理一个用户请求,另外PHP目前只有中间码(opcode),仍然需要解释执行,这也会牺牲性能(可能后续版本会加入JIT功能)。PHP的简化设计思想使得其不适合做高并发和大计算量的任务,但很适合广大的中小型网站,这也是为什么Facebook费了老大力气自己实现了个HHVM的原因。
测试数据和结论
上面只是粗略的理论分析,这里有一个Benchmark数据表,测试用例是从数据库读取若干数据并显示:
https://www.techempower.com/benchmarks/#section=data-r13&hw=ph&test=fortune
里面的测试数据很有参考价值,这里简单归纳下和本文相关部分:
1.Java Servlet(Resin服务器)和NodeJS在不实现ORM的情况下,速度相当快,其中Java要稍胜一筹。
2.原生PHP的速度要差了一倍多:
而nodejs在完整实现了ORM的情况下,速度居然能和原生PHP相近,且使用postgres时,性能不如mysql。
3.Java的主流开发框架play和spring表现如下,相差不多,比PHP的Yii2和Larval要高4倍左右:
而Yii2的性能比Laravel(未实现ORM的情况下)要高30%左右,而Laravel在实现了ORM的情况下,性能要更低。
4.还有一个有意思的地方是,hhvm对于简单的数据库读取显示,并不能带来多大好处,这个也好理解,因为代码量不多,计算量不大。
5.另外nodejs的几个开发框架express/hapi/sails的性能表现并不好(实现了ORM的情况下),尤其是sails很慢。meteor的性能也口碑不佳,这可能是其架构过于强调实时更新(基于Socket.io)而引起的额外服务负担,并非所有应用都是即时聊天或多人对战游戏。总体上个人认为对于meteor/sails这些nodejs MVC框架,当前阶段可以尝试学习和在一些边缘项目(比如聊天类)上练手,别轻易把原先使用Java/PHP/.Net构建的电商主业务迁移过来,除非你有足够的时间、经费和资源来自行排除各种应用坑(尤其是处理关系型数据上),代码、社区和文档都还不稳定。
最新评论
参考阅读:
https://projectricochet.com/blog/top-10-meteor-performance-problems
参考阅读:https://rclayton.silvrback.com/speaking-intelligently-about-java-vs-node-performance
参考阅读:http://www.infoworld.com/article/2975233/javascript/why-node-js-beats-java-net-for-web-mobile-iot-apps.html
- 相关文章
2019年NodeJS框架Koa和Express选型比较
Koa和Express都是NodeJS的主流应用开发框架。
Express是一个完整的nodejs应用框架。Koa是由Express团队开发的,但是它有不同的关注点。Koa致力于核心中间件...JavaScript事件模型图解
在JavaScript中用户交互的核心部分就是事件处理。本文为对事件模型和处理机制的总体性描述。Event是什么?
event是用户操作网页时发生的交互动作,比如clic...常见面试题JS语言中四种函数调用方式实例讲解
JS的语言世界中函数(function)是一等公民,函数的调用有多种方法。普通调用这个是最常见和直接的方式:function
HTTP1.1协议现状、问题和解决方案
HTTP的现状最早的HTTP协议非常简单,只能用来传送文本,方法也只有GET,后来逐步发展到1.1,能够支持多种MIME格式数据(如文本、文件),支持GET,POST,HEAD,OPTI...
使用SVG和CSS3创建圆形进度条动画
圆形进度条是一个经典的控制面板元素,常用于显示任务进度,比如用户档案的完整程度,或者升级状态。有很多方法来实现圆形进度条,比如用JS, CSS3, Canvas, SVG...
三维向量的简单运算和实用意义
在WebGL的实际应用中我们广泛使用向量的几何运算来计算角度、距离,判断点线、点面之间的关系,比如物体之间的碰撞检测。本文简要介绍三维计算机图形学中常用的...
Blender2.7 快捷键一览表
通用操作
停止当前操作:ESC
快捷搜索:SPACE撤销:ctrl+z重做:ctrl+shift+z渲染:F12
单选:鼠标右键(RMB)全选:A
框选:B
刷选:...Three.js入门教程4 - 创建粒子系统动画
嗨,又见面了。这么说我们已经开始学习Three.js了,如果你还没有看过之前三篇教程,建议你先读完。如果你已经读完前面的教程了,你可能会想做一些关于粒子的东西。让我们直面这个话题吧,每个人都爱粒子效果。不管你是否知道,你可以很轻易地创建它们。
D3.js读取外部json数据
D3.js是一个很好的数据可视化工具,支持从web服务读取json数据,或者从外部文件如.json, .csv文件中直接读取。由于部分服务比如flickrs上的图文数据服务需要VPN...
inline-block元素设置overflow:hidden属性导致相邻行内元素向下偏移
在表单修改界面中常会使用一个标签、一个内容加一个修改按钮来组成单行界面,如图1所示。那么在表单总长度受限的情况下,当中间的邮箱名称过长时,会遮盖到旁边...
如何使用CSS3实现一个3D商品标签
使用3D缎带形状的标签是常见的一个设计模式,用在商品折扣、文章标题或网站推荐信息上,来突出显示重点内容,吸引用户视觉焦点。实现的方法有2种,一种是使用背...
使用纯CSS3实现一个3D旋转的书本
有一些前沿的电商网站已经开始使用3D模型来展示商品并支持在线定制,而其中图书的展示是最为简单的一种,无需复杂的建模过程,使用图片和CSS3的一些变换即可实现...
如何使用纯CSS3实现一个3D泡沫
要实现一个逼真的泡沫,涉及到比较复杂的光学/物理学知识。我们这里先简化下问题,实现一个相对简单而足够实用的泡沫元素。我们可以把基础的泡沫元素应用在很多场景中,比如水景、泡咖啡、啤酒甚至火焰特效中。泡沫首先是一个圆形元素.bubble
更多...