nodejs,使用oboe发送大流或大JSON文件有些错误

时间:2017-11-08 09:00:10

标签: node.js stream oboe.js

我从一台服务器(例如: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

如果我无法减少信息,我该如何改进,或者我是否必须以其他方式做某事?

高地:http://highlandjs.org/ 双簧管:http://oboejs.com/

1 个答案:

答案 0 :(得分:1)

嘿,我看到这篇文章有点陈旧,但我遇到了类似的问题,而且我只能使用节点来解决这个问题。

我的目录已针对此测试进行相应设置:

.
├── s1
│   └── lorem.txt
├── s2
├── server.js
└── transmitter.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);

server.js

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中显示的完全相同。

显然,还有很多工作要做,以使这个产品有价值,但希望这有助于下一个人像我一样在这里徘徊。