美文网首页
重学Node

重学Node

作者: 刘昊2018 | 来源:发表于2020-05-31 20:34 被阅读0次

    重学Node

    JavaScript能力从浏览器延伸到服务器端

    NodeJs并不是一种语言,是一种架构。

    chrome v8引擎

    10年

    JavaScript变得重要起来

    从玩具语言变成了严肃的工程化的语言

    融合了动态语言特性 面向对象 函数式两种范式的语言

    npm 使用第三方包

    性能和效率是极高的

    本质上单线程 异步非阻塞

    回调地狱

    Promise 承诺 以同步的表现形式来去解决异步的问题
    使代码读起来更加容易理解

    前后端分离

    nodejs.org

    最开始几年发展的并不快 nodejs - iojs - nodejs
    npmjs.org

    server.listen(port,host);

    server.on('listening',callback);
    server.on('connection',callback);
    server.on('close',callback);
    server.on('request',callback);

    http fs util url querystring path dns内置原生模块

    __dirname 当前目录

    exports
    module.export

    模块加载机制

    尽最大可能去使用异步版本

    Buffer

    Buffer.alloc();
    Buffer.from();
    Buffer.contact();

    Net
    对tcp提供了强有力的支援

    WebSocket HTML5规范
    是基于http协议 upgrade

    http1.1 keepalive 减少连接频繁创建销毁

    全双工通信 对等的两端
    http2本质上支持长连接

    node.js原生模块中没有对websocket提供支持

    socket.io

    事件机制 观察者模式

    Events
    on == addListener
    针对同一个事件可以添加多个监听
    once 只处理一次事件回调
    off == removeListener
    removeAllListeners

    newListener内置事件

    Node本身能够做到如此高性能的根本原因在于事件(Event)的使用,
    以及对于监听者(listener,callback)的调用上。

    本质上,当Node启动一个文件或服务器后,Node实际上运行在一个死循环中,
    在这个死循环中,Node会不断发射事件,监听事件并且执行回调逻辑。

    事件来源主要有两种:一是Node自身所发射出的事件,二是来自于Node自身所运行的环境。
    监听事件:回调都是要依附于相应的事件的。
    执行回调逻辑:本质上都是由底层来执行的。

    关于IO操作的异步执行逻辑:
    1.同步模式
    2.异步模式 poll epoll

    所谓的单线程,指的是Node的逻辑执行主线程是单线程的,即JavaScript代码运行所处的
    的线程,这是个单线程。因为JavaScript本身只能执行在单线程当中。

    线程池
    windows: iocp
    linux: libuv

    一定不能阻塞主线程

    当我们在程序中引入了某个第三方模块时,那么整体的全部执行逻辑为:
    Node -> 第三方模块 -> 原生模块 -> 原生模块内部的实现 ->
    c++模块 -> libuv -> 线程池 -> 线程 -> 执行底层的io操作(涉及到操作系统调用)

    Node完整的事件循环逻辑
    1.启动Node运行时
    2.检测是否有待处理事件
    3.如果没有,回调循环开始
    4.如果有,那么从事件队列中取出一个事件
    5.判断当前这个事件有没有与之关联的事件处理器(回调)
    6.如果没有,回到循环开始
    7.如果有,则执行事件的回调逻辑
    8.回到循环开始,开始新一轮事件检测流程

    整个Node的执行过程实际上是由完整的事件循环机制,底层的操作
    系统异步io调用,线程池(底层库实现由操作系统提供)共同配合完成的。

    Nginx 也是单线程 事件 回调

    对于单线程的Node来说,是否无法利用多核的优势呢?

    对于Node主线程来说,它只能运行在一个核心上面。
    对于底层线程池来说,他们却可以运行在多个核心上面,因此他们是完全
    可以利用到多核的优势的。

    mysql
    mongoose
    ioredis

    代码分层
    db service controller app.js

    koa koajs.com
    express

    洋葱模型
    middlleware

    context上下文

    两种使用模式
    1.后端全部纯粹使用JavaScript开发
    2.NodeJS作为中间层,请求预处理

    @koa/router
    koa-bodyparser
    koa-static
    koa-compress 请求体压缩
    koa-combine-routers 路由组合
    axios
    jsonfile

    工程目录结构:
    app
    common
    config
    controller
    router
    scripts
    util
    projectConfig.json

    pm2 监控Node.js进程活跃情况的工具

    相关文章

      网友评论

          本文标题:重学Node

          本文链接:https://www.haomeiwen.com/subject/btwrzhtx.html