Ошибка Node.js: процесс порождения ffmpeg ChildProcessError - PullRequest
1 голос
/ 10 июня 2019

Я хотел просто создать такую ​​программу, как OBS.

Мое идеальное поведение кода - создать дочерний процесс в Node.js и выполнить команды FFMPEG для отправки потока веб-камеры на ваш RTMP-сервер livetube. Однако фактическое поведение вызвано ошибкой в ​​модуле обещания дочернего процесса, используемого в файле node.js.

Я проверил несколько вопросов, но у меня недостаточно опыта, чтобы понять их, и я надеюсь, что есть четкое решение.

Полагаю, это потому, что я не смог найти адрес команды FFMPEG в среде Node. Или вызов из среды сокетов является проблемой?

Я проверил, что команда FFMPEG работает в среде приглашения Windows.

※ Примечание. Переменные среды FFMPEG зарегистрированы.

Среда: Window10, node.js, ffmpeg

Код воспользовался простым примером WebSocket.

Когда я впервые провел исследование, я подумал, что единственный способ сделать это - использовать «fluent-effmpeg».

Я попробовал "fluent-ffmpeg", но я не смог настроить веб-камеру своего ноутбука в Windows и использовать ее в качестве параметра команды "fluent-ffmppeg".

Я тоже думал об использовании WebRTC, но думаю, что это не для личного использования, потому что это P2P-соединение. (Я также видел, как подключить одноранговое соединение к серверу WebRTC, например, к Janus, но у меня не было достаточно ссылок, чтобы это понять.)

Ниже приведен код проблемы.

const SocketIO = require("socket.io");
const ffmpeg = require("fluent-ffmpeg");
const spawn = require("child-process-promise").spawn;

module.exports = server => {
  const io = SocketIO(server, { path: "/socket.io" });

  io.on("connection", socket => {
    const req = socket.request;
    const ip = req.headers["x-forwarded-for"] || req.connection.remoteAddress;
    console.log("새로운 클라이언트 접속!", ip, socket.id, req.ip);
    socket.on("disconnect", () => {
      console.log("클라이언트 접속해제", ip, socket.id);
      clearInterval(socket.interval);
    });
    socket.on("error", error => {
      console.error(error);
    });
    socket.on("reply", data => {
      console.log(data);
      ffmpeg_command();
    });
  });

  function ffmpeg_command() {
    let arg = [
      "-f",
      "lavfi",
      "-i",
      "anullsrc=r=16000:cl=mono",
      "-f",
      "dshow",
      "-ac",
      "2",
      "-i",
      "video='HP Truevision HD'",
      "-s",
      "1280x720",
      "-r",
      "10",
      "-vcodec",
      "libx264",
      "-pix_fmt",
      "yuv420p",
      "-preset",
      "ultrafast",
      "-r",
      "25",
      "-g",
      "20",
      "-b:v",
      "2500k",
      "-codec:a",
      "libmp3lame",
      "-ar",
      "44100",
      "-threads",
      "6",
      "-b:a",
      "11025",
      "-bufsize",
      "512k",
      "-f",
      "flv",
      "rtmp://a.rtmp.youtube.com/live2/8dfu-69k0-dxyw-896q"
    ];
    spawn("ffmpeg", arg).catch(e => {
      console.log(e);
    });
  }
};

Вот ошибка: ожидаемый результат - ваша веб-камера работает, и прямая трансляция с YouTube прошла успешно.

{ ChildProcessError: `ffmpeg -f lavfi -i anullsrc=r=16000:cl=mono -f dshow -ac 2 -i video='HP Truevision HD' -s 1280x720 -r 10 -vcodec libx264 -pix_fmt yuv420p -preset ultrafast -r 25 -g 20 -b:v 2500k -codec:a libmp3lame -ar 44100 -threads 6 -b:a 11025 -bufsize 512k -f flv rtmp://a.rtmp.youtube.com/live2/8dfu-69k0-dxyw-896q` failed with code 1
    at ChildProcess.<anonymous> (C:\Users\Tricky\Desktop\Work\ESC\ESC_temp\node_modules\child-process-promise\lib\index.js:132:23)
    at ChildProcess.emit (events.js:182:13)
    at ChildProcess.cp.emit (C:\Users\Tricky\Desktop\Work\ESC\ESC_temp\node_modules\child-process-promise\node_modules\cross-spawn\lib\enoent.js:40:29)
    at maybeClose (internal/child_process.js:962:16)
    at Socket.stream.socket.on (internal/child_process.js:381:11)
    at Socket.emit (events.js:182:13)
    at Pipe._handle.close (net.js:606:12)
  name: 'ChildProcessError',
  code: 1,
  childProcess:
   ChildProcess {
     _events: { error: [Function], close: [Function] },
     _eventsCount: 2,
     _maxListeners: undefined,
     _closesNeeded: 3,
     _closesGot: 3,
     connected: false,
     signalCode: null,
     exitCode: 1,
     killed: false,
     spawnfile: 'ffmpeg',
     _handle: null,
     spawnargs:
      [ 'ffmpeg',
        '-f',
        'lavfi',
        '-i',
        'anullsrc=r=16000:cl=mono',
        '-f',
        'dshow',
        '-ac',
        '2',
        '-i',
        'video=\'HP Truevision HD\'',
        '-s',
        '1280x720',
        '-r',
        '10',
        '-vcodec',
        'libx264',
        '-pix_fmt',
        'yuv420p',
        '-preset',
        'ultrafast',
        '-r',
        '25',
        '-g',
        '20',
        '-b:v',
        '2500k',
        '-codec:a',
        'libmp3lame',
        '-ar',
        '44100',
        '-threads',
        '6',
        '-b:a',
        '11025',
        '-bufsize',
        '512k',
        '-f',
        'flv',
        'rtmp://a.rtmp.youtube.com/live2/8dfu-69k0-dxyw-896q' ],
     pid: 18928,
     stdin:
      Socket {
        connecting: false,
        _hadError: false,
        _handle: null,
        _parent: null,
        _host: null,
        _readableState: [ReadableState],
        readable: false,
        _events: [Object],
        _eventsCount: 1,
        _maxListeners: undefined,
        _writableState: [WritableState],
        writable: false,
        allowHalfOpen: false,
        _sockname: null,
        _pendingData: null,
        _pendingEncoding: '',
        server: null,
        _server: null,
        [Symbol(asyncId)]: 132,
        [Symbol(lastWriteQueueSize)]: 0,
        [Symbol(timeout)]: null,
        [Symbol(kBytesRead)]: 0,
        [Symbol(kBytesWritten)]: 0 },
     stdout:
      Socket {
        connecting: false,
        _hadError: false,
        _handle: null,
        _parent: null,
        _host: null,
        _readableState: [ReadableState],
        readable: false,
        _events: [Object],
        _eventsCount: 2,
        _maxListeners: undefined,
        _writableState: [WritableState],
        writable: false,
        allowHalfOpen: false,
        _sockname: null,
        _pendingData: null,
        _pendingEncoding: '',
        server: null,
        _server: null,
        write: [Function: writeAfterFIN],
        [Symbol(asyncId)]: 133,
        [Symbol(lastWriteQueueSize)]: 0,
        [Symbol(timeout)]: null,
        [Symbol(kBytesRead)]: 0,
        [Symbol(kBytesWritten)]: 0 },
     stderr:
      Socket {
        connecting: false,
        _hadError: false,
        _handle: null,
        _parent: null,
        _host: null,
        _readableState: [ReadableState],
        readable: false,
        _events: [Object],
        _eventsCount: 2,
        _maxListeners: undefined,
        _writableState: [WritableState],
        writable: false,
        allowHalfOpen: false,
        _sockname: null,
        _pendingData: null,
        _pendingEncoding: '',
        server: null,
        _server: null,
        write: [Function: writeAfterFIN],
        [Symbol(asyncId)]: 134,
        [Symbol(lastWriteQueueSize)]: 0,
        [Symbol(timeout)]: null,
        [Symbol(kBytesRead)]: 1615,
        [Symbol(kBytesWritten)]: 0 },
     stdio: [ [Socket], [Socket], [Socket] ],
     emit: [Function] },
  stdout: undefined,
  stderr: undefined }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...