サーチ…


fsとパイプを使用してサーバーから静的ファイルをストリーミングする

良いVOD(ビデオ・オン・デマンド)サービスは、基本から始めるべきです。あなたのサーバー上のディレクトリには、ユーザーがメディアにアクセスできるようにする何らかのポータルやpaywallを介して、一般にアクセスできないディレクトリがあるとします。

var movie = path.resolve('./public/' + req.params.filename);

        fs.stat(movie, function (err, stats) {

            var range = req.headers.range;

            if (!range) {

                return res.sendStatus(416);

            }

            //Chunk logic here
            var positions = range.replace(/bytes=/, "").split("-");
            var start = parseInt(positions[0], 10);
            var total = stats.size;
            var end = positions[1] ? parseInt(positions[1], 10) : total - 1;
            var chunksize = (end - start) + 1;

            res.writeHead(206, {

                'Transfer-Encoding': 'chunked',

                "Content-Range": "bytes " + start + "-" + end + "/" + total,

                "Accept-Ranges": "bytes",

                "Content-Length": chunksize,

                "Content-Type": mime.lookup(req.params.filename)

            });

            var stream = fs.createReadStream(movie, { start: start, end: end, autoClose: true })

                .on('end', function () {

                    console.log('Stream Done');

                })

                .on("error", function (err) {

                    res.end(err);

                })

                .pipe(res, { end: true });

        });

上のスニペットは、ビデオをクライアントにストリーミングする方法の基本的な概要です。チャンクロジックは、ネットワークトラフィックやレイテンシを含むさまざまな要因に依存します。チャックサイズと量のバランスをとることが重要です。

最後に、.pipe呼び出しにより、node.jsは、サーバーとの接続を開いたままにし、必要に応じて追加のチャンクを送信することを知ることができます。

Fluent-ffmpegを使ったストリーミング

flent-ffmpegを使用して、.mp4ファイルを.flvファイル、または他のタイプに変換することもできます。

res.contentType( 'flv');

    var pathToMovie = './public/' + req.params.filename;

    var proc = ffmpeg(pathToMovie)

        .preset('flashvideo')

        .on('end', function () {

            console.log('Stream Done');

        })

        .on('error', function (err) {

            console.log('an error happened: ' + err.message);

            res.send(err.message);

        })

        .pipe(res, { end: true }); 


Modified text is an extract of the original Stack Overflow Documentation
ライセンスを受けた CC BY-SA 3.0
所属していない Stack Overflow