NodeJS学习笔记之网络编程


Posted in NodeJs onAugust 03, 2014

Node提供丰富的网络编程模块

Node模块 协议
net TCP
dgram UDP
http HTTP
https HTTPS

TCP服务事件分为下面两类

(1)、服务器事件

对于通过net.createServer()创建的服务器而言,它是一个EventEmitter实例,自定义事件有以下几种:

listening :在调用listen()绑定端口或Domain Socket后触发,简写为server.listen(port, listener),通过第二个参数传入。

connection :每个客户端套接字连接到 服务器 时触发,简洁写法为通过net.createServer(),最后一个参数传递。

close :当服务器关闭时触发,在调用server.close()后,服务器将停止接受新的套接字连接,但保持当前存在的连接,等待所有连接断开后,会触发该事件。

error :当服务器发生异常时,将会触发该事件。

(2)、连接事件

服务器可以同时与多个客户端保持连接,对于每个连接而言是典型的可写可读Stream对象。Stream对象可以用于服务端和客户端之间的通信,既可以通过data事件从一端读取另一端发来的数据,也可以通过write()方法从一端向另一端发送数据。

data :当一端调用write()发送数据时,另一端会触发data事件,事件传递的数据就是write()发送的数据

end :当连接中的任意一端发送FIN数据时,将会触发该事件。

connect :该事件用于 客户端 ,当套接字与服务器连接成功时会触发。

drain :当任意一端调用write()发送数据时,当前这端触发该事件。

error :当异常发送

close :当套接字完全关闭时触发

timeout :当一定时间后连接不再活跃时,触发该事件通知用户该连接被闲置了。

TCP针对网络中的小数据包有一定优化策略:Nagle算法,当数据达到一定量后才触发。

UDP服务

UDP称为用户数据包协议,其不是面向连接的服务。Node中UDP只是一个EventEmitter实例,而非Stream的实例,具备以下自定义事件:

(1) message :当UDP套接字监听网卡端口后,接受消息时触发,触发携带的数据为消息Buffer对象和一个远程地址信息。

(2) listening :当UDP套接字开始侦听时触发该事件。

(3) close :调用close()方法时触发该事件,并不再触发message事件。若需再次触发message事件,需要重新绑定。

(4) error :当异常发生时触发,若不监听直接抛出,使进程退出。

HTTP服务

Node中http模块继承自tcp服务器(net模块),它能与多个客户端保持连接,由于其不为每个连接创建线程,保持很低的内存占用,所以能实现高并发。HTTP服务和TCP服务区别在于,在开启keepalive之后,一个TCP会话可以用于多次请求和响应。TCP服务以connection为单位进行服务,HTTP服务以request单位进行服务。http模块是将connection到request的过程进行封装。

http模块将连接所用的套接字的读写抽象为ServerRequest和ServerResponse对象,分别对应请求和响应操作。

(1) HTTP请求

对于TCP连接的读操作,http模块将其封装为ServerRequest对象。如报头部分req.method、req.url、req.headers,报文体数据部分抽象为一个只读的流对象,若业务逻辑需要读取报文体中的数据,则需要这个数据流结束后才能进行操作。

(2) HTTP响应

HTTP响应封装了底层连接的写操作,可以将其看成一个可写的流对象。

响应报文头部信息方法:res.setHeader()和res.writeHeader()方法,可以多次setHeader进行设置,但必须调用writeHeader写入连接才生效。

报文体部分方法:res.write()和res.end()方法

(3) HTTP服务端事件

connection :客户端与服务端建立TCP连接时,触发一次connection事件

request :建立TCP连接后,http模块底层将数据流中抽象出HTTP请求和HTTP响应,当请求数据发送到服务端,在解析出HTTP请求头后触发该事件;在res.end()后,TCP连接可用于下一次请求。

close :调用server.close方法停止接收新的连接,已有的连接都断开时触发该事件。

checkContinue :某些客户端在发送较大数据时,先发送一个头部带有Expect: 100-continue的请求到服务器,服务触发该事件;

connect :当客户端发起CONNECT请求时触发

upgrade :当客户端要求升级连接的协议时,需要和服务端协商,客户端会在请求头中带上Updagrade字段

clientError :连接的客户端发送错误,错误传到服务端此时触发该事件

(4) HTTP客户端

http模块提供http.request(options, connect),用于构造HTTP客户端。

HTTP客户端和服务端类似,在ClientRequest对象中,它的事件叫做response,ClientRequest在解析响应报文的时,一解析完响应头就触发response事件,同时传递一个响应对象ClientResponse供操作,后续响应报文以只读流的方式提供。

(5) HTTP客户端事件

response :与服务端的request事件对应的客户端在请求发出后得到响应时触发该事件。

socket :当底层连接池中建立的连接分配给当前请求对象时触发;

connect :当客户端向服务器发送CONNECT请求时,若服务端响应了200状态码,客户端将会触发该事件。

upgrade :客户端享服务端发送Upgrade请求时,若服务端响应了101 Switching Protocols状态,客户端将会触发该事件。

continue :客户端向服务端发起Expect: 100-continue头信息后,以试图发送较大数据,若服务端响应100 continue状态,服务端将触发该事件

WebSocket服务

WebSocket最早是作为HTML5重要特性出现的,相比HTTP有以下优点:

(1) 客户端和服务端只建立一次TCP连接,可以使用更少的连接

(2) WebSocket服务端可以推送数据到客户端,这远比HTTP请求响应模式更灵活、更高效

(3) 更轻量级的协议头,减少数据传输

Node中没有内置WebSocket的库,但社区的ws模块封装了WebSocket的底层实现如著名的socket.io

NodeJs 相关文章推荐
利用NodeJS的子进程(child_process)调用系统命令的方法分享
Jun 05 NodeJs
Google官方支持的NodeJS访问API,提供后台登录授权
Jul 29 NodeJs
Nodejs中调用系统命令、Shell脚本和Python脚本的方法和实例
Jan 01 NodeJs
基于html5和nodejs相结合实现websocket即使通讯
Nov 19 NodeJs
nodejs 搭建简易服务器的图文教程(推荐)
Jul 18 NodeJs
Windows下使用Nodejs运行js的方法
Sep 02 NodeJs
nodejs实现大文件(在线视频)的读取
Oct 16 NodeJs
详解webpack打包nodejs项目(前端代码)
Sep 19 NodeJs
nodejs遍历文件夹下并操作HTML/CSS/JS/PNG/JPG的方法
Nov 01 NodeJs
使用nodejs实现JSON文件自动转Excel的工具(推荐)
Jun 24 NodeJs
NodeJS开发人员常见五个错误理解
Oct 14 NodeJs
基于 Docker 开发 NodeJS 应用
Jul 30 #NodeJs
Google官方支持的NodeJS访问API,提供后台登录授权
Jul 29 #NodeJs
使用nodejs、Python写的一个简易HTTP静态文件服务器
Jul 18 #NodeJs
抛弃Nginx使用nodejs做反向代理服务器
Jul 17 #NodeJs
nodejs的10个性能优化技巧
Jul 15 #NodeJs
提高NodeJS中SSL服务的性能
Jul 15 #NodeJs
在NodeJS中启用ECMAScript 6小结(windos以及Linux)
Jul 15 #NodeJs
You might like
substr()函数中文版
2006/10/09 PHP
解析php多线程下载远程多个文件
2013/06/25 PHP
PHP实现Soap通讯的方法
2014/11/03 PHP
PHP在线书签系统分享
2016/01/04 PHP
PHP信号量基本用法实例详解
2016/02/12 PHP
PHP中session跨子域的三种实现方法
2016/07/25 PHP
一个实用的php验证码类
2017/07/06 PHP
javaScript Array(数组)相关方法简述
2009/07/25 Javascript
JavaScript Distilled 基础知识与函数
2010/04/07 Javascript
jquery 查找新建元素代码
2010/07/06 Javascript
node.js中的path.resolve方法使用说明
2014/12/08 Javascript
JavaScript获取页面中第一个锚定文本的方法
2015/04/03 Javascript
如何判断Javascript对象是否存在的简单实例
2016/05/18 Javascript
JS实现的自定义水平滚动字体插件完整实例
2016/06/17 Javascript
原生JS封装ajax 传json,str,excel文件上传提交表单(推荐)
2016/06/21 Javascript
使用React实现轮播效果组件示例代码
2016/09/05 Javascript
jQuery窗口拖动功能的实现代码
2017/02/04 Javascript
jQuery控制元素隐藏和显示
2017/03/03 Javascript
用React-Native+Mobx做一个迷你水果商城APP(附源码)
2017/12/25 Javascript
10分钟彻底搞懂Http的强制缓存和协商缓存(小结)
2018/08/30 Javascript
jQuery无冲突模式详解
2019/01/17 jQuery
[01:02:20]Mineski vs TNC 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
python获取Linux下文件版本信息、公司名和产品名的方法
2014/10/05 Python
Linux下编译安装MySQL-Python教程
2015/02/02 Python
Python利用pandas计算多个CSV文件数据值的实例
2018/04/19 Python
Python使用googletrans报错的解决方法
2018/09/25 Python
Django通过设置CORS解决跨域问题
2020/11/26 Python
python 操作excel表格的方法
2020/12/05 Python
安装不同版本的tensorflow与models方法实现
2021/02/20 Python
Clearly澳大利亚:购买眼镜、太阳镜和隐形眼镜
2018/04/26 全球购物
Zalando Lounge瑞士:时尚与生活方式购物俱乐部
2020/03/12 全球购物
试用期员工考核制度
2014/01/22 职场文书
工会趣味活动方案
2014/08/18 职场文书
以权谋私检举信范文
2015/03/02 职场文书
opencv-python图像配准(匹配和叠加)的实现
2021/06/23 Python
Python人工智能之混合高斯模型运动目标检测详解分析
2021/11/07 Python