我有这个:
const p = path.resolve(projectRoot + '/NAMEDPIPEIN');
const fd = fs.openSync(p, 'r+');
fs.createReadStream(null, {fd}).on('data', function (d) {
if (String(d).trim() === '[stdin end]') {
return process.nextTick(cb);
}
process.argv.push(String(d).trim());
});
我启动Node.js进程,然后,我写入命名管道。出于某种原因,数据似乎没有到达数据回调中。
我正在写命名管道:
mkfifo NAMEDPIPEIN
echo "foo bar baz" > NAMEDPIPEIN
答案 0 :(得分:4)
来自@richardpringle的另一种解决方案应该可以工作,但是会遇到一个问题。
如果您尝试以这种方式打开多个(超过4个)fifo,则您打开的第一个fifo将不再流式传输数据。
从https://stackoverflow.com/a/52622722/1843507开始,从fifo实现流式传输的当前方法是使用套接字:
const fs = require('fs');
const net = require('net');
fs.open('path/to/fifo/', fs.constants.O_RDONLY | fs.constants.O_NONBLOCK, (err, fd) => {
// Handle err
const pipe = new net.Socket({ fd });
// Now `pipe` is a stream that can be used for reading from the FIFO.
pipe.on('data', (data) => {
// process data ...
});
});
答案 1 :(得分:2)
这应该这样做:
const fs = require('fs');
const path = require('path');
const fifoPath = path.resolve(projectRoot, '/NAMEDPIPEIN')
const fifo = fs.createReadStream(fifoPath);
fifo.on('data', data => {
// process data...
});
使用fifo.on('data', console.log)
进行测试。