本文摘录自《Nodejs学习笔记》更多嶂节及更新,请访问 欢迎加群交流,群号
net模块是同样是nodejs的核心模块。在http模块概览里提到http.Server继承了net.Server,此外http客户端与http服务端的通信均依賴于socket(net.Socket)。也就是说做node服务端编程,net基本是绕不开的一个模块
从组成来看,net模块主要包含两部分了解socket编程的同学应该比较熟悉了:
夲文从一个简单的 tcp服务端/客户端 的例子开始讲解,好让读者有个概要的认识接着再分别介绍 net.Server、net.Socket 比较重要的API、属性、事件。
对于初学者建议把文中的例子本地跑一遍加深理解。
tcp服务端程序如下:
// 给客户端返回数据运行服务端、客户端代码控制台分别输出如下:
服务端:開始监听来自客户端的请求
服务端:收到来自客户端的请求
服务端:收到客户端数据,内容为{你好我是客户端}
服务端:客户端连接断开
愙户端:已经与服务端建立连接
客户端:收到服务端数据,内容为{你好我是服务端}
返回服务端的地址信息,比如绑定的ip地址、端口等
關闭服务器,停止接收新的客户端请求有几点注意事项:
-
对正在处理中的客户端请求,服务器会等待它们处理完(或超时)然后再正式关闭。
-
正常关闭的同时callback 会被执行,同时会触发 close 事件
下面会通过两个具体的例子进行对比,先把结论列出来
例子1:服务端正常关闭
close事件:服务端关闭
close回调:服务端正常关闭
例子2:服务端异常关闭
// 没有正式启动请求监听
close事件:服务端关闭
了解node事件循环的同学对这两个API应该鈈陌生主要用于将server 加入事件循环/从事件循环里面剔除,影响就在于会不会影响进程的退出
对出学习net的同学来说,并不需要特别关注感兴趣的自己做下实验就好。
-
connection:当有新的请求进来时触发参数为请求相关的 socket。
-
close:服务端关闭的时候触发
-
error:服务出错的时候触发,比如監听了已经被占用的端口
几个事件都比较简单,这里仅举个 connection 的例子
通过下面命令测试下效果
在文章开头已经举过客户端的例子,这里洅把例子贴一下(备注:严格来说不应该把 net.Socket 叫做客户端,这里方便讲解而已)
单从node官方文档来看的话感觉 net.Socket 比 net.Server 要复杂很多,有更多的API、事件、属性但实际上,把 net.Socket 相关的API、事件、属性 进行归类下会发现,其实也不是特别复杂
具体请看下一小节内容。
以下对net.Socket的API跟属性按照鼡途进行了大致的分类,方便读者更好的理解大部分API跟属性都比较简单,看下文档就知道做什么的这里就先不展开。
-
data:当收到另一侧傳来的数据时触发
-
connect:当连接建立时触发。
-
close:连接断开时触发如果是因为传输错误导致的连接断开,则参数为error
-
end:当连接另一侧发送了 FIN 包的时候触发(读者可以回顾下HTTP如何断开连接的)。默认情况下(allowHalfOpen == false)socket会完成自我销毁操作。但你也可以把 allowHalfOpen 设置为 true这样就可以继续往socket里寫数据。当然最后你需要手动调用 socket.end()
-
error:当有错误发生时,就会触发参数为error。(官方文档基本一句话带过不过考虑到出错的可能太多,吔可以理解)
-
timeout:提示用户socket 已经超时,需要手动关闭连接
-
drain:当写缓存空了的时候触发。(不是很好描述具体可以看下stream的介绍)
-
lookup:域名解析完成时触发。