为了账号安全,请及时绑定邮箱和手机立即绑定

NODE个人学习笔记分享

标签:
Node.js

webp

前言:本篇是个人学习nodejs的笔记,github仓库地址已贴出

=> github仓库地址

NodeJs 进阶学习


Node特性(解决web服务器高性能瓶颈问题)

  • 1.单线程

相对其他服务器开发语言来说,像java、php,用户每一次请求都会为用户创建单独的线程,会增大服务器的开销,可能会造成内存严重不足,需要使用多台
服务器。 而node则是单线程,不会独立创建单独的线程,从而减少服务器硬件上的开销。node通过内部事件,当用户连接时就会触发,通过非阻塞I/O、事件驱动机制,让node宏观上来看也是"并发执行"的,一个8G的内存服务器可处理同时4万的连接,同时它也能解决服务器线程开销的时间。

缺点: 因为是单线程,当某个用户线程崩溃,那么导致了其他用户也会崩溃

  • 解决: pm2(出现崩溃服务会照常运行不会造成整个服务停止)   pm2 start app.js  pm2 list  pm2 log app

  • 2.非阻塞I/O

传统服务器开发,进行I/O操作,比如数据库读写,往往会等到查询的结果,代码才会继续往下执行,这就造成了堵塞,而node则是放到回调函数中,等待返回结果
在执行回调函数,不会造成堵塞,它会对CPU的利用率更高。--------有了非阻塞并不能解决问题,还需借助事件循环机制


  1. 事件驱动

在比如客户端建立连接、发送请求、提交数据时,都会触发相对应的事件,而在某一个时刻,只能处理一个事件的回调函数,而在处理某一个事件的回调函数时,又可以转化为其他事件,然后返回执行原有事件的回调函数,从而产生了事件循环。Node底层是用c++写的,V8也是基于c++,c++,在底层代码中,多数都是用事件队列、回调函数队列的构建。用事件队列来完成服务器的任务调度。队列也有优先级。

Node适合干什么

因为基于node的特性,善于I/O,不善于计算,如果业务中有大批量的计算服务,实际上也相当于阻塞了这个线程,node不适合做这样的开发。
当应用程序处理大批量并发的I/O时,而在响应之前不需要大批量的计算,内部处理时,nodejs非常适合。nodejs也非常适合长连接的项目开发,非常适合
与websocket结合,开发实时交互的应用程序。比如:用户表单收集、考试系统、聊天室、图文直播、提供JSON API服务

  • Node 可以挑战PHP、Java、?等传统服务器开发语言吗

答案是无法比拟的,因为很多企业追求的是可靠的服务,node是一种工具,它在处理某一块时是非常有用的。然而很多企业也都在用node处理某一块业务功能

Node安装

推荐使用nvm(包括线上的生产环境搭建)

nvm install v8.10.0 安装 node
nvm use v8.10.0 nvm 指定使用的 node 的版本
nvm alias default v8.10.0 设置 node 默认使用版本
npm config set registry https://registry.npm.taobao.org 设置淘宝镜像
增加系统文件监控数目 echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p

Node模块进阶API学习




作者:可爱的圣诞老人
链接:https://www.jianshu.com/p/e1faa46ce551


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消