我从一台服务器(例如:127.0.0.1:3000)向另一台服务器发送文件(例如:127.0.0.1:3001),我发现当文件过大时,传输将会出现问题。< / p>
例如:
//127.0.0.1:3000
router.post('/getStream',function(req, res, next){
function getResultStream(){
return new Promise(function(resolve, reject){
oboe('http://127.0.0.1:3001/getEnvelopeResult_2')
.done(function(things) {
resolve(things);
}).node(function(e){
console.log(e);
})
.fail(function(e) {
console.log(e);
reject(e);
});
});
}
getResultStream().then(function(body){
res.json({data:body});
}).catch(function(err){
res.json({message:err});
});
});
例如另一台服务器:
我将获得一个json file.json
并转换为Stream
。
//127.0.0.1:3001
app.get('/getStream',function(req, res, next){
let path="json/file.json";
oboe(fs.createReadStream(path))
.done(function(things) {
send(things,res);
})
.fail(function(e) {
res.json({message:e});
});
function send(things,res){
things.errorArray = JSON.parse(things.errorArray);
let json = JSON.stringify(things);
highland([
json
])
.invoke('split', [''])
.sequence()
.pipe(res)
}
});
file.json
大约3000 KB。
像这样的内容:
{"array":"[{\"No\":1,\"tyep\":\"none\",\"checkflag\":true,\"active\":true,\"time\":\"2017-11-08T07:04:49.024Z\"}...30000 pieces ]
"file":"axzf",
"last":30000,
"start":1
}
这个array
的绝大部分容量约为30,000。
我试过10,000和20,000和30,000 ......,失败了。
只有少于1100的array
才能成功传播。
错误信息的一部分:
{ statusCode: undefined,
body: undefined,
jsonBody: undefined,
thrown:
Error: Max buffer length exceeded: textNode
Ln: 1
Col: 131072
Chr: undefined
at Error (native)
at emitError
at emitOne (events.js:96:13)
at IncomingMessage.emit (events.js:188:7)
at readableAddChunk (_stream_readable.js:176:18)
at IncomingMessage.Readable.push (_stream_readable.js:134:10)
at HTTPParser.parserOnBody (_http_common.js:123:22)
at Socket.socketOnData (_http_client.js:363:20)
at emitOne (events.js:96:13)
at Socket.emit (events.js:188:7)
at readableAddChunk (_stream_readable.js:176:18)
at Socket.Readable.push (_stream_readable.js:134:10)
at TCP.onread (net.js:547:20) }
maxActual = Math.max(maxActual, textNode.length);
^
TypeError: Cannot read property 'length' of undefined
at checkBufferLength
如果我无法减少信息,我该如何改进,或者我是否必须以其他方式做某事?
答案 0 :(得分:1)
嘿,我看到这篇文章有点陈旧,但我遇到了类似的问题,而且我只能使用节点来解决这个问题。
我的目录已针对此测试进行相应设置:
.
├── s1
│ └── lorem.txt
├── s2
├── server.js
└── transmitter.js
鉴于此,我能够使用以下代码解决此问题:
const http = require('http');
const fs = require('fs');
const requestOpts = {
hostname: 'localhost',
port: 1337,
method: 'POST'
};
const readStream = fs.createReadStream('./s1/lorem.txt');
const request = http.request(requestOpts);
readStream.pipe(request);
const http = require('http');
const fs = require('fs');
http.createServer((request, response) => {
const writeStream = fs.createWriteStream('./s2/lorem.txt');
request.on('data', (chunk) => {
writeStream.write(chunk);
});
request.on('end', () => {
writeStream.close();
response.end();
});
}).listen(1337);
您可以在一个终端窗口中运行node server.js
,然后在另一个终端窗口中运行transmitter.js
来测试。
lorem.txt
目录中s2
的结果应与s1
中显示的完全相同。
显然,还有很多工作要做,以使这个产品有价值,但希望这有助于下一个人像我一样在这里徘徊。