为什么node.js不适合大型项目


Posted in Javascript onApril 28, 2021

前言

首先要明确什么是大型应用,其实这是仁者见仁、智者见智的问题,并且它是一个哲学问题,不是一个技术问题。假如有人问你,一个可以进行线上销售的网站,比如优衣库,大不大?你可能会说大,因为这与你平常所见的博客、企业官网等逻辑相比较确实复杂很多。或者说小,那么说明你开发过比它还复杂的系统。那么相比较淘宝而言呢?大和小的对比是要有参照物的。

1. 应用的组成

一个完备的 Web 应用可能只由一门语言或者一种技术构成吗?不可能。因为一个完备的 Web 应用其实是多门技术的综合体,解决某个问题有非常多的解决方案,比如后端的逻辑解决方案就非常多,Java、php、Python、Ruby 等都可以。

简单地概述,应用的组成内容可能包括:

Web 界面显示逻辑;后端业务逻辑;缓存;数据库;消息队列。

其实还可以加入日志分析、数据分析等,只是上面几个最广为人知而已。

2. 应用的种类

I/O 密集型;CPU 密集型。

就常见的互联网产品而言,它的瓶颈并非在后端业务的逻辑上,而是在 I/O 上,即返回给用户看的数据的读入与输出。相对于应用程序而言,读入指的是从数据库里获取数据,而输出指的是将这些数据经过一定的处理输出到用户的浏览器,那么这就是 I/O 密集型。

而CPU密集型是指做频繁计算任务的应用,Node.js在这方面确实是短板。

3. 应用服务的过程

如图所示,用户通过浏览器发送请求,由网卡接收TCP 连接,通知内核,内核再去调用相对应的服务端程序。

Request 请求过程

为什么node.js不适合大型项目

Response 返回过程

如下图,Web 应用要返回数据,首先要获取数据,通过内核调用磁盘的驱动程序,把数据读入缓存,这样就可以在 Web 应用程序中获取数据并进行数据处理,最终调用内核,将数据通过网卡发送给客户端。

为什么node.js不适合大型项目

4. 应用的瓶颈

通常 I/O 密集型的瓶颈会在磁盘的读写上,所以在购买云服务器的时候可以购买 SSD 的磁盘来提升性能,一般数据库软件的数据都是存储在文件上面的。首先考虑添加内存型缓存来解决这个瓶颈,缓存经常访问的数据,看能否解决当前场景的问题,比如使用 Redis。其次才考虑搭建或扩充数据库集群来提高并发。

而 CPU 密集型的应用瓶颈则在 CPU 上,只能增加 CPU 处理核心来解决瓶颈。

5. 分布式应用

大型的普通应用与分布式应用其实是不同的概念。读者可以把分布式应用简单地理解为一个团队,每一个成员都是一个节点,一个大的项目要让成员合作完成,那么成员与成员之间就存在一些沟通成本,甚至有的成员与成员之间勾心斗角,说话阳奉阴违、推脱责任,也有可能成员生病在家休养,无法工作,等等。在面对这些问题的时候,Node.js的优势并不能很好地显现出来(并非不可以做,只是没有完善的基础设施)。

分布式的真正定义是,在多台不同的服务器中部署不同的服务模块,以进程为基本单位,派发到服务器上,通过远程调用(RPC)通信并协同工作,最终对外提供服务。

相比较Node.js目前的分布式基础设施,Go 语言的基础设施则完善多了,特别是在 Docker 这个项目上,充分证明了 Go 语言的优势,这也是为什么 Node.js 社区“大牛”TJ Holowaychuk 转向 Go 语言,因为他要开发分布式应用。

其实没必要过分地关心分布式的问题,毕竟JavaScript最初只是一个运行在浏览器端的脚本语言而已,JavaScript不是万能的,为什么一定要把它用在操作系统级别的开发上呢?寻找一个更合适的语言不是更好吗?就像此刻我们选择 JavaScript 构建 Web 应用一样。

6. 多进程的 Node.js

了解了以上的一些知识点,现在读者应该知道,Node.js 跟大型应用关系不大。大多数学习 Node.js 的开发者是前端开发者,所以对后端的基础知识并不了解,在网络上搜寻一些资料的时候发现 Node.js 只能利用单核,而又听说 TJ Holowaychuk 转向 Go 的阵营,所以有的开发者就产生了Node.js不适合开发大型应用的疑问。

Node.js 只能利用单核的问题已经被解决了,后面使用的 Egg.js框架中的 Egg-Cluster 模块就利用多进程非常好地解决了这个问题。

以上就是为什么node.js不适合大型项目的详细内容,更多关于node.js的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
奇妙的js
Sep 24 Javascript
javaScript 利用闭包模拟对象的私有属性
Dec 29 Javascript
MooBox 基于Mootools的对话框插件
Jan 20 Javascript
使用javascript创建快捷方式的简单实例
Aug 09 Javascript
jQuery实现数秒后自动提交form的方法
Mar 05 Javascript
JavaScript实现点击按钮直接打印
Jan 06 Javascript
JS中多步骤多分步的StepJump组件实例详解
Apr 01 Javascript
如何利用模板将HTML从JavaScript中抽离
Oct 08 Javascript
Ionic 2 实现列表滑动删除按钮的方法
Jan 22 Javascript
JQuery实现图片轮播效果
May 08 jQuery
JS常用正则表达式总结【经典】
May 12 Javascript
mui开发中获取单选按钮、复选框的值(实例讲解)
Jul 24 Javascript
JavaScript控制台的更多功能
Apr 28 #Javascript
JavaScript使用canvas绘制坐标和线
JS Object构造函数之Object.freeze
Apr 28 #Javascript
关于vue中如何监听数组变化
vue实现简单数据双向绑定
Apr 28 #Vue.js
JS异步堆栈追踪之为什么await胜过Promise
Apr 28 #Javascript
vue引入Excel表格插件的方法
Apr 28 #Vue.js
You might like
用PHP和ACCESS写聊天室(五)
2006/10/09 PHP
php二维数组合并及去重复的方法
2015/03/04 PHP
magento后台无法登录解决办法的两种方法
2016/12/09 PHP
Laravel Validator自定义错误返回提示消息并在前端展示
2019/05/09 PHP
Laravel使用模型实现like模糊查询的例子
2019/10/24 PHP
JS.GetAllChild(element,deep,condition)使用介绍
2013/09/21 Javascript
jquery获取一个元素下面相同子元素的个数代码
2014/07/31 Javascript
3种Jquery限制文本框只能输入数字字母的方法
2014/12/03 Javascript
ECMAScript6函数剩余参数(Rest Parameters)
2015/06/12 Javascript
今天抽时间给大家整理jquery和ajax的相关知识
2015/11/17 Javascript
jquery获取复选框checkbox的值实现方法
2016/05/30 Javascript
js移动焦点到最后位置的简单方法
2016/11/25 Javascript
Bootstrap学习笔记之环境配置(1)
2016/12/07 Javascript
微信小程序开发之入门实例教程篇
2017/03/07 Javascript
详解Vue用自定义指令完成一个下拉菜单(select组件)
2017/10/31 Javascript
JavaScript 对引擎、运行时、调用堆栈的概述理解
2018/10/22 Javascript
小程序分享模块超级详解(推荐)
2019/04/10 Javascript
vue实现路由不变的情况下,刷新页面操作示例
2020/02/02 Javascript
vue中父子组件传值,解决钩子函数mounted只运行一次的操作
2020/07/27 Javascript
Python实现的简单发送邮件脚本分享
2014/11/07 Python
Python中的tuple元组详细介绍
2015/02/02 Python
Django使用HttpResponse返回图片并显示的方法
2018/05/22 Python
python 实现敏感词过滤的方法
2019/01/21 Python
Python创建字典的八种方式
2019/02/27 Python
对python3.4 字符串转16进制的实例详解
2019/06/12 Python
Python join()函数原理及使用方法
2020/11/14 Python
CSS3 :not()选择器实现最后一行li去除某种css样式
2016/10/19 HTML / CSS
canvas实现圆绘制的示例代码
2019/09/11 HTML / CSS
世界上最大的在线学习和教学市场:Udemy
2017/11/08 全球购物
Vertbaudet西班牙网上商店:婴儿服装、童装、母婴用品和儿童家具
2019/10/16 全球购物
师范毕业生个人求职信
2013/12/09 职场文书
最经典的大学生职业生涯规划范文
2014/03/05 职场文书
同学聚会邀请函
2015/01/30 职场文书
事业单位个人总结
2015/02/12 职场文书
windows11怎么查看wifi密码? win11查看wifi密码的技巧
2021/11/21 数码科技
Nginx+Windows搭建域名访问环境的操作方法
2022/03/17 Servers