这是我参与「第四届青训营 」笔记创作活动的第11天
Node.js运行结构
node.js的运行结构有三个特点
- 异步I/O
- 单线程
- 跨平台
异步I/O
当Node.js执行I/O操作时,会在响应返回后操作,而不是阻塞线程并占用额外内存等待。举一个生活中的例子理解一下,就是相当于预约,比如预约一张演唱会的门票,他会先让很多人排队预约,不回立即得到门票,等一段时间后再进行回调,就是把门票送到你手中。如果不是异步操作,就相当于买火车票,在窗口,你提出买火车票就能立即买到,但是这样会有一个问题,当你拿不出身份证或者其他原因使得无法给你办理火车票,后面排队的人就会觉得很慢,造成了队很长,后面排队的会不耐烦。
异步调用过程
readFile()方法申请异步调用,node处理请求,然后接着其他的异步调用,处理请求成功后返回数据,然后再执行回调。
单线程
- 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',
}))
})
})