node.js中net网络模块TCP服务端与客户端的使用
node.js中net模块为我们提供了TCP服务器和客户端通信的各种接口。
一、创建服务器并监听端口
const net = require('net'); //创建一个tcp服务
//参数一表示创建服务的一些配置
//参数二表示 事件 'connection' 监听回调函数
let server = net.createServer({
//表示是否允许一个半开的TCP连接,默认为false
allowHalfOpen: false,
//一旦来了连接,是否暂停套接字,默认为false
pauseOnConnect: false
}); server.listen(6666); //一个新的连接建立时触发 'connection' 事件
server.on('connection', function (socket) {
//注意这里的socket是一个流,既可以读,也可以写
//当我们监听 'data' 事件后,系统就会不断的从流中读取数据
socket.on('data', function (data) {
console.log('服务器接收到 : ', data.toString());
});
}); //服务调用 server.listen() 监听后就会触发该事件
server.on('listening', function () {
// address() 方法返回服务器地址信息对象
let addr = server.address();
console.log(`服务器监听 : ${addr.port} 端口`);
}); //服务关闭时触发,如果还有连接存在,则直到所有连接结束才会触发该事件
server.on('close', function () {
console.log('服务关闭');
}); //出现错误时触发
server.on('error', function (err) {
console.log(err);
});
windows下可以通过telnet 或 xshell,putty等工具连接上该服务,进行交互。
我们可以通过 getConnections() 实时获取当前服务器的连接数。
const net = require('net'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始');
}); //一个新的连接建立时触发 'connection' 事件
server.on('connection', function (socket) { //获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); socket.on('data', function (data) {
console.log('服务器接收到 : ', data.toString());
});
});
我们可以手动的设置服务器的最大连接数,如果超过该连接数,则会拒绝连接。
const net = require('net'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始'); //设置最大连接数为3,当有第4个连接请求时,连接会拒绝。
server.maxConnections = 3;
}); //一个新的连接建立时触发 'connection' 事件
server.on('connection', function (socket) { //获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); socket.on('data', function (data) {
console.log('服务器接收到 : ', data.toString());
});
});
我们也可以使用 close() 手动的拒绝所有连接请求,当已连接的客户端都关闭后,则服务器会自动关闭,并触发 'close' 事件。
const net = require('net'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始');
}); //一个新的连接建立时触发 'connection' 事件
server.on('connection', function (socket) {
//获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); socket.on('data', function (data) {
console.log('服务器接收到 : ', data.toString());
});
}); server.on('close', function () {
console.log('服务器被关闭');
}); //5秒后手动关闭服务器,拒绝所有连接请求,已有连接全部关闭后,触发 'close' 事件
setTimeout(function () {
server.close();
}, 5000);
调用 unref() 后,则当所有客户端连接关闭后,将关闭服务器。ref() 功能与 unref() 相反。
const net = require('net'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始');
}); //一个新的连接建立时触发 'connection' 事件
server.on('connection', function (socket) {
//获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); socket.on('data', function (data) {
console.log('服务器接收到 : ', data.toString());
}); socket.on('close', function () {
console.log('客户端关闭'); //调用unref()后,当所有客户端连接都关闭后,将关闭服务器
server.unref();
});
}); server.on('close', function () {
console.log('服务器关闭');
});
二、net.Socket是一个socket端口对象,是一个全双工的可读可写流
const net = require('net'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始');
}); server.on('connection', function (socket) {
//获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); console.log('客户端信息 : ', socket.address()); //接收到数据时触发
socket.on('data', function (data) {
//我们可以从流中读取数据
console.log('服务器接收到 : ', data.toString());
console.log('累计接收的数据大小 : ', socket.bytesRead);
console.log('累计发送的数据大小 : ', socket.bytesWritten); //也可以向流中写入数据
let flag = socket.write(`服务器向你发送 : ${data.toString()} \r\n`);
console.log('flag : ', flag);
console.log('当前已缓冲并等待写入流中的字节数 : ', socket.bufferSize);
}); //连接关闭时触发
socket.on('end', function () {
console.log('客户端关闭');
}); //连接完全关闭时触发
socket.on('close', function () {
console.log('客户端完全关闭');
}); //发生错误时触发
socket.on('error', function (err) {
console.log(err);
});
});
我们可以通过 puase() 和 resume() 方法暂停读写数据。
const net = require('net'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始');
}); server.on('connection', function (socket) {
//获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); //接收到数据时触发
socket.on('data', function (data) {
console.log('接收到的数据 : ', data.toString()); setTimeout(function () {
//3秒后暂停读取数据
socket.pause();
}, 3000); setTimeout(function () {
//6秒后恢复读取数据
socket.resume();
}, 6000);
});
});
net.Socket对象是一个流,既然是流,那么我们可以通过 pipe() 方法建一个到文件的可写流,把从客户端接收的数据写入到一个文件中。
const net = require('net');
const fs = require('fs'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始');
}); let ws = fs.createWriteStream('./1.txt'); server.on('connection', function (socket) {
//获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); //接收到数据时触发
socket.on('data', function (data) {
console.log('接收到的数据 : ', data.toString());
}); //注意这里的第二个参数,设为 false。
//每当有一个新的连接时,就会创建一个新的 socket 对象。
//不然当第一个socket对象结束操作或关闭时,会自动关闭 ws 可写流。
//后续的socket对象将无法往 ws 里写入数据。
socket.pipe(ws, {end: false}); socket.on('end', function () {
console.log('客户端关闭');
socket.unpipe(ws);
});
});
通过 setTimeout() 我们可以设置一个连接活动的超时时间,当一个连接超时时,将触发 'timeout' 事件。
const net = require('net'); let server = net.createServer();
server.listen(6666, '0.0.0.0', function () {
console.log('服务器监听开始');
}); server.on('connection', function (socket) {
//获取当前服务器的连接数
server.getConnections(function (error, count) {
console.log('当前服务器的连接数 : ', count);
}); //接收到数据时触发
socket.on('data', function (data) {
console.log('接收到的数据 : ', data.toString());
}); socket.setTimeout(3 * 1000);
//连接超时后,并不会断开,需手动调用 end() 或 destroy() 来断开连接
socket.on('timeout', function () {
console.log('当前连接已超时');
});
});
三、创建一个tcp客户端
const net = require('net'); //创建一个tcp客户端
let client = new net.Socket();
client.connect({
host: '127.0.0.1',
port: 6666
}); //客户端与服务器建立连接触发
client.on('connect', function () {
client.write('你好服务器');
}); //客户端接收数据触发
client.on('data', function (data) {
console.log('服务器发送的数据 : ', data.toString());
});
客户端可以通过调用 end() 方法来主动关闭与服务端的连接。
const net = require('net'); //创建一个tcp客户端
let client = new net.Socket();
client.connect({
host: '127.0.0.1',
port: 6666
}); //客户端与服务器建立连接时触发
client.on('connect', function () {
//往服务端写入数据
client.write('你好服务器');
}); //客户端接收数据时触发
client.on('data', function (data) {
console.log('服务器发送的数据 : ', data.toString());
}); setTimeout(function () {
client.end();
}, 3000);
通过 setKeepAlive() 方法来禁用或启用长连接功能,防止时间过短而断开连接。setKeepAlive() 会发送一个空包,来保持通信。
const net = require('net'); //创建一个tcp客户端
let client = new net.Socket();
client.connect({
host: '127.0.0.1',
port: 6666
}); //设置连接保持
client.setKeepAlive(true, 3000); //客户端与服务器建立连接触发
client.on('connect', function () {
client.write('你好服务器');
}); //客户端接收数据触发
client.on('data', function (data) {
console.log('服务器发送的数据 : ', data.toString());
}); setTimeout(function () {
client.end();
}, 3000);
node.js中net网络模块TCP服务端与客户端的使用的更多相关文章
- 网络聊天室---node.js中net网络模块TCP服务端与客户端的使用
//1.简单创建 net服务器 // const net = require("net"); // const server = net.createServer((c)=> ...
- node.js中ws模块创建服务端和客户端,网页WebSocket客户端
首先下载websocket模块,命令行输入 npm install ws 1.node.js中ws模块创建服务端 // 加载node上websocket模块 ws; var ws = require( ...
- 【转】TCP/UDP简易通信框架源码,支持轻松管理多个TCP服务端(客户端)、UDP客户端
[转]TCP/UDP简易通信框架源码,支持轻松管理多个TCP服务端(客户端).UDP客户端 目录 说明 TCP/UDP通信主要结构 管理多个Socket的解决方案 框架中TCP部分的使用 框架中UDP ...
- 基于Select模型的Windows TCP服务端和客户端程序示例
最近跟着刘远东老师的<C++百万并发网络通信引擎架构与实现(服务端.客户端.跨平台)>,Bilibili视频地址为C++百万并发网络通信引擎架构与实现(服务端.客户端.跨平台),重新复习下 ...
- swoole创建TCP服务端和客户端
服务端: server.php <?php //创建Server对象,监听 127.0.0.1:9501端口 $serv = new swoole_server("127.0.0 ...
- node.js中使用http模块创建服务器和客户端
node.js中的 http 模块提供了创建服务器和客户端的方法,http 全称是超文本传输协议,基于 tcp 之上,属于应用层协议. 一.创建http服务器 const http = require ...
- TCP/UDP简易通信框架源码,支持轻松管理多个TCP服务端(客户端)、UDP客户端
目录 说明 TCP/UDP通信主要结构 管理多个Socket的解决方案 框架中TCP部分的使用 框架中UDP部分的使用 框架源码结构 补充说明 源码地址 说明 之前有好几篇博客在讲TCP/UDP通信方 ...
- vertx 从Tcp服务端和客户端开始翻译
写TCP 服务器和客户端 vert.x能够使你很容易写出非阻塞的TCP客户端和服务器 创建一个TCP服务 最简单的创建TCP服务的方法是使用默认的配置:如下 NetServer server = ve ...
- C++封装的基于WinSock2的TCP服务端、客户端
无聊研究Winsock套接字编程,用原生的C语言接口写出来的代码看着难受,于是自己简单用C++封装一下,把思路过程理清,方便自己后续翻看和新手学习. 只写好了TCP通信服务端,有空把客户端流程也封装一 ...
随机推荐
- springboot 集成mybatis plus3
gradle: compile group: 'com.baomidou', name: 'mybatis-plus-boot-starter', version: '3.0.1' MybatisPl ...
- Python递归调用
递归调用:在调用一个函数过程中,直接或间接又调用该函数本身,称之为递归调用 递归必备的2个阶段 1递推 2回溯 当递推结束后就可以进行回溯了 Python默认设置递归层数为1000 递归示例: de ...
- Window10下安装sbt
参考:https://segmentfault.com/a/1190000002474507 下载:https://dl.bintray.com/sbt/native-packages/sbt/0.1 ...
- vm虚拟机 模板机进行克隆导致centos 7.2 无法加载网卡
问题描述:vm虚拟机 模板机进行克隆导致centos 7.2 无法加载网卡. 1.ifconfig 查看网卡状态 lo: flags=<UP,LOOPBACK,RUNNING> mtu i ...
- Keras处理已保存模型中的自定义层(或其他自定义对象)
如果要加载的模型包含自定义层或其他自定义类或函数,则可以通过 custom_objects 参数将它们传递给加载机制: from keras.models import load_model # 假设 ...
- 未预期的符号 `$'{\r'' 附近有语法错误
../runcmake: 行 2: $'\r': 未找到命令 ../runcmake: 行 3: 未预期的符号 `$'{\r'' 附近有语法错误 考虑到代码是从windows下一直过来的,脚本可能在格 ...
- CDC工具使用
最近一直在搞CDC (clock domain crossing) 方面的事情,现在就CDC的一些知识点进行总结. 做CDC检查使用的是0in工具. 本来要 写一些关于 CDC的 知识点,临时有事,要 ...
- 用户名、密码等15个常用的js正则表达式
本文收集整理了15个常用的javaScript正则表达式,其中包括用户名.密码强度.整数.数字.电子邮件地址(Email).手机号码.身份证号.URL地址. IPv4地址. 十六进制颜色. 日期. Q ...
- Java的synchronized的同步代码块和同步方法的区别
synchronized同步方法和同步代码块的区别 同步方法默认使用this或者当前类做为锁. 同步代码块可以选择以什么来加锁,比同步方法更精确,我们可以选择只有会在同步发生同步问题的代码加锁,而并不 ...
- 格式化hdfs后,hadoop集群启动hdfs,namenode启动成功,datanode未启动
集群格式化hdfs后,在主节点运行启动hdfs后,发现namenode启动了,而datanode没有启动,在其他节点上jps后没有datanode进程!原因: 当我们使用hdfs namenode - ...