客户端收到所有.ts文件后自动删除.ts和.m3u8文件

问题描述 投票:1回答:2

所以我创建了一个获取mp3文件的快速服务器(现在存储在本地,但稍后将从mongo db中获取)并使用ffmpeg制作.m3u8和.ts文件。文件成功发送到客户端,在客户端播放时没有错误。我使用hls.js在Chrome中播放这些文件。但是服务器仍然存储本地存储的文件。有没有办法让服务器知道何时删除它存储在本地的文件? ffmpeg生成了很多文件,所以我不能让它们永远留在那里。

我使用了hls-server github repo代码的ffmpeg部分。

my server file

index.js

// just used to run ffmpeg for conversion
var command = ffmpeg('inp.mp3')
  .on('start', function (commandLine) {
    console.log('command', commandLine);
  }).addOptions([
    '-c:a aac',
    '-b:a 64k',
    '-vn',
    '-hls_list_size 0',
    '-segment_time 10',
  ]).output('files\\output.m3u8');

var express = require('express');
var app = express();
// express middleware to serve individual .ts and .m3u8 files when requested
app.use(express.static('./files/'));

app.get('/', function (req, res) {
  command.on('end', function () {
    console.log('done');
    res.write(`
    <script src="https://cdn.jsdelivr.net/hls.js/latest/hls.min.js"></script>
    <script>
      function onLevelLoaded (event, data) {
        var level_duration = data.details.totalduration;
        console.log(level_duration, data);
      }
      if(Hls.isSupported()) {
        var audio = new Audio();
        var hls = new Hls();
        // requesting files from here
        hls.loadSource('http://localhost:8000/output.m3u8');
        hls.attachMedia(audio);
        hls.on(Hls.Events.LEVEL_LOADED, onLevelLoaded);
        hls.on(Hls.Events.FRAG_BUFFERED, (e, d) => {
          console.log(e, d);
        });
      }
    </script>
    `);
    res.end();
  }).run();
});

app.listen(8000);
express ffmpeg hls
2个回答
1
投票

你可以使用hls_delete_threshold

"-hls_time 10",
"-hls_list_size 3",
"-hls_delete_threshold 3", 
"-hls_flags delete_segments"

hls_delete_threshold size

在hls_flags delete_segments删除它们之前,设置要保留在磁盘上的未引用段的数量。增加此项以允许继续客户端下载最近在播放列表中引用的段。默认值为1,表示将删除早于hls_list_size + 1的段。


0
投票

这就是我在ffmpeg过程中所做的:-hls_list_size 6 -hls_flags delete_segments

这有效地推动了它们。它会在创建新的时自动删除最旧的一个。

现在,我可能做错了,因为我保留了6个以上的文件,但肯定会删除大部分文件。

© www.soinside.com 2019 - 2024. All rights reserved.