日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

对node.js的net模块的一个测试

發(fā)布時(shí)間:2023/12/20 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 对node.js的net模块的一个测试 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

抄表系統(tǒng)在接收電表發(fā)回的數(shù)據(jù)的時(shí)候,發(fā)現(xiàn)有些電表發(fā)回的數(shù)據(jù)沒(méi)有被socket端口接收到,最后等待時(shí)間耗盡,留下了指令超時(shí)的記錄。因?yàn)槭窃谶M(jìn)行虛擬的測(cè)試,因此可以根據(jù)對(duì)服務(wù)器發(fā)的tcp報(bào)文進(jìn)行分析,分析結(jié)果發(fā)現(xiàn)在發(fā)出抄表指令之后1s之內(nèi),虛擬的電表就返回了抄表結(jié)果,然后socket服務(wù)器沒(méi)有收到這個(gè)記錄。

因此做了這個(gè)測(cè)試,來(lái)測(cè)試抄表時(shí)間和抄表數(shù)量對(duì)于socket服務(wù)器有什么影響。

服務(wù)器端:

var net = require('net'); var fs = require('fs');var server = net.createServer(function (socket) {socket.on('data', function (data) {data = JSON.parse(data);// console.log(data.i + ' : ' + data.curr);var record = data.i + ' : ' + data.curr + '\r\n';fs.appendFile("./服務(wù)器日志.txt", record, function(err) {if (err) {console.log("指令記錄失敗:" + record);}});var time = new Date();var current = data.i + ' : ' + time.getFullYear() + "-" + (time.getMonth() + 1) + "-" + time.getDate() + " " + time.getHours() + ":" + time.getMinutes() + ":" + time.getSeconds() + ":" + time.getMilliseconds() + " 服務(wù)器端 ====>> 客戶端" ;socket.write(current);});socket.on('end',function () {console.log('連接斷開(kāi)');});socket.on('error',function () {console.log('連接斷開(kāi)');}) });server.listen(8814, function() {console.log('server start!'); });

客戶端:

var net = require('net'); var fs = require('fs');var i = 1;var client = net.connect({port:8814}, function() {setInterval(emmit, 500);// client.end(); });function emmit() {if (i <= 4000) {console.log(i);var time = new Date();var current = time.getFullYear() + "-" + (time.getMonth() + 1) + "-" + time.getDate() + " " + time.getHours() + ":" + time.getMinutes() + ":" + time.getSeconds() + ":" + time.getMilliseconds() + " 客戶端 ====>> 服務(wù)器端" ;var data = {};data.curr = current;data.i = i;data = JSON.stringify(data);client.write(data);};i++; }client.on('data', function(data) {// console.log(data.toString());var record = data.toString() + '\r\n';fs.appendFile("./客戶端日志.txt", record, function(err) {if (err) {console.log("指令記錄失敗:" + record);}}); });client.on('end', function() {console.log('client disconnected'); });client.on('error', function() {console.log('server error!'); });

?

轉(zhuǎn)載于:https://www.cnblogs.com/lswit/p/5016914.html

總結(jié)

以上是生活随笔為你收集整理的对node.js的net模块的一个测试的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。