nodejs开发网站的性能足够吗?
网上很多人挺nodejs,但众所周知,node的优势在于io并发上面,而且是单线程的,如果访问的人特别多,而且逻辑有点复杂,node应付得过来吗?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
网上很多人挺nodejs,但众所周知,node的优势在于io并发上面,而且是单线程的,如果访问的人特别多,而且逻辑有点复杂,node应付得过来吗?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(4)
首先,在一个进程内,你写的代码看似是单线程,但其内部所有发出的IO操作(文件读写、网络请求等)并不是单线程的,比如同时发出n个异步请求,这n个异步请求都是各自有单独的线程去,主线程只是轮询处理这些成功回调。
其次,借助pm2,你的程序可以在一台服务器上拷贝出N个同样进程,这样就可以实现多进程运行了。
目前,我们上线API接口跑在2台8核服务器上,每台服务器通过pm2开启8个API进程+10个后台服务进程,通过负载均衡每秒可以处理500~600个请求,一天就3千万了。
性能是足够的,NodeJS底层采用了libevent(基于epoll那一套) + Javascript8引擎,速度杠杠的。
性能和效率是没问题的,问题就是目前生态环境还不如java那么丰富...
在并发方面, NodeJS = Go = Scala可以认为这3者基本上一个级别的。
但大型网站目前的难点已经不是负载均衡了,而是合理的利用数据,这个需要Hadoop,需要Hbase,需要Kafka,也就是Java的生态环境还是必不可少的。
除了并发,其实Node还能做不少事情,据说钉钉的桌面版基于Node的,见这里
你可以看一下这个网站做的benchmark
https://www.techempower.com/benchmarks/
nodejs适合io密集的场景, CPU密集的需要可以多线程的, 如JAVA. JAVA对于IO密集的场景由于线程切换的消耗,得不偿失.nodejs对于cpu密集的场景, 会阻塞异步事件完成(单线程).