Node.js运行结构 | 青训营笔记

80 阅读2分钟

这是我参与「第四届青训营 」笔记创作活动的第11天

Node.js运行结构

node.js的运行结构有三个特点

  • 异步I/O
  • 单线程
  • 跨平台

异步I/O

当Node.js执行I/O操作时,会在响应返回后操作,而不是阻塞线程并占用额外内存等待。举一个生活中的例子理解一下,就是相当于预约,比如预约一张演唱会的门票,他会先让很多人排队预约,不回立即得到门票,等一段时间后再进行回调,就是把门票送到你手中。如果不是异步操作,就相当于买火车票,在窗口,你提出买火车票就能立即买到,但是这样会有一个问题,当你拿不出身份证或者其他原因使得无法给你办理火车票,后面排队的人就会觉得很慢,造成了队很长,后面排队的会不耐烦。

异步调用过程

readFile()方法申请异步调用,node处理请求,然后接着其他的异步调用,处理请求成功后返回数据,然后再执行回调。

image.png

单线程

  • JS单线程: 实际:JS线程+uv线程池+V8任务线程池+V8 Inspector线程
  • 优点:不用考虑多线程状态同步问题,也就不需要锁;同时还能比较高效地利用系统资源。
  • 缺点:阻塞会产生更多负面影响
  • 解决办法:多进程或多线程

跨平台

  • 跨平台(面对大部分功能、api)
  • node.js+JS无需编译环境(+web跨平台+诊断工具平台)
  • =开发成本地(大部分场景无需担心跨平台问题),整体来说学习成本低

HTTP Server

hello world

//引用http模板
const http=require('http')
//设置端口
const port =3000
// 创建server返回hello,world
const server=http.createServer((req,res)=>{
    res.end("hello,world")
    })
    //监听server
    server.listen(port,()=>{
    console.log(server listen on: ${port})
    })

JSON

const server=http.createServer((req,res)=>{
    req.on('data',data=>{
        bufs.push(data)
    })
    req.on('end',()=>{
    let reqData={}
    try{
        reqData-JSON.parse(Buffer.concat(bufs).toString())
        }catch(err){
        }
        res.setHeader('Content-Type','application/json')
        res.end(JSON.stringify({
            echo:reqData.msg || 'hello,world',
            }))
        })
    })