我想我缺少一些基本的东西,因为我对 Node 服务器还很陌生。
我们的应用程序非常基础。服务器应该接收少量文本行(数据),合并并解析它们,一旦连接关闭(数据发送结束),它就会将数据发送到 api。
var net = require('net');
var fs = require('fs');
const axios = require('axios')
const server = new net.Server();
server.listen(PORT, IP);
server.on("connection", client => {
client.write("Hello\n");
console.log('connected');
let received = "";
client.on("data", data => {
received += data
console.log("Partial data is: " + data);
});
client.on("close", () => {
received = received.toString('utf8');
fs.appendFile('log.txt', received, function (err) {});
received = received.replace(/(?:\r\n|\r|\n)/g, "||");
axios.post(APIADDRESS, {data: received});
console.log('Full data is: '+ {data: received});
});
});
要发送数据,我只是运行 anetcat或nc使用netcat ipaddress port,这不是问题。连接正常,收到状态消息。
问题是——一旦我从两个不同的 SSh 服务器打开两个或多个连接,就会发生一些奇怪的事情。我可以一行接一行地发送就好了。服务器报告“部分数据”调试没有问题,对于他们两个。但是,一旦我关闭其中一个连接 (ctrl+c),它们都会关闭。最后,只收到来自手动关闭连接的数据。另一个来自单独的ncssh 服务器的单独服务器似乎永远无法到达该client.on("close")部分。它只是无缘无故地终止了。
有任何想法吗?我什至不知道从哪里开始。
//EDIT 刚刚从我的电脑和一些使用单独的 SSH 服务器的 ssh 移动应用程序测试了它。一旦在任何设备上发送 ctrl+c,它就会关闭所有客户端的连接。
//忘了说我正在运行 pm2 来保持服务器正常运行。一旦我手动打开脚本,忽略 pm2 - 它工作正常。诡异的。它的发生是因为 PM2.5。
aluckdog
鸿蒙传说
相关分类