历史纪录
更新内容
- 使用 concat 资源列表替代普通文件输入流,将多个视频合并到同个流中推送,防止断流。
注意事项
- 要求同一个 concat 列表中的视频文件格式、编码、尺寸相同,否则视频间切换时虽然不断流但会出现奇怪的现象。
- 本文代码继承上个版本特点,自动读取目标文件夹中的视频文件,然后顺序随机生成一个 concat.txt 列表文件,不需要手动编写列表。
- 同样建议配合 pm2 进程守护使用。
Nodejs 代码
var fs = require('fs');
var sd = require('silly-datetime');
var ffmpeg = require('fluent-ffmpeg');
var D = './video2/';
var L = './pic/tips2.png';
var R = 'rtmp://txy.live-send.acg.tv/live-txy/';
var C = '?streamname=live_0000000_1111111&key=1f8a9f1h8j8q4h5x6i5s6f8n1z2i3dq7';
var O = '';
function showTime() {
return sd.format(new Date(), 'YYYY-MM-DD HH:mm');
}
function randomV() {
return 0.5 - Math.random();
}
function liveON(inputPath) {
var outputPath = (O == '' ? (R + C) : O);
ffmpeg(inputPath)
.inputOptions('-re')
.inputOptions('-ac 2')
.inputOptions('-f concat')
.inputOptions('-safe 0')
.addInput(L)
.complexFilter([{
filter: 'scale',
options: [1280, -1],
inputs: '[0:v]',
outputs: 'video'
}, {
filter: 'scale',
options: [220, -1],
inputs: '[1:v]',
outputs: 'logo'
}, {
filter: 'overlay',
options: {
x: 'main_w-overlay_w-15',
y: 15
},
inputs: ['video', 'logo']
}])
.on('start', function(commandLine) {
console.log('[' + showTime() + '] Vedio is Pushing !');
console.log('[' + showTime() + '] Spawned Ffmpeg with command !');
console.log('[' + showTime() + '] Command: ' + commandLine);
})
.on('error', function(err, stdout, stderr) {
console.log('error: ' + err.message);
console.log('stdout: ' + stdout);
console.log('stderr: ' + stderr);
})
.on('end', function() {
console.log('[' + showTime() + '] Vedio Pushing is Finished !');
})
.addOptions([
'-vcodec libx264',
'-preset veryfast',
'-crf 22',
'-maxrate 1000k',//1000k
'-bufsize 3000k',
'-acodec libmp3lame',
'-ac 2',
'-ar 44100',
'-b:a 96k'
])
.format('flv')
.output(outputPath, {
end: true
})
.run();
}
function start() {
var V = fs.readdirSync(D).sort(randomV);
var N = V.length;
var concat = '';
console.log('[' + showTime() + '] Find ' + N + ' Video Files !');
for(var i = 0; i < N; i++) {
concat += "file '" + D + V[i] + "'" + (i == N-1 ? "" : "\r\n");
}
fs.writeFile('concat.txt', concat, (err) => {
if (err) throw err;
liveON("concat.txt");
});
}
start();
截至发文,该代码已在腾讯云不间断运行超过一个月 ---> http://live.bilibili.com/64285
版权属于:香菇
本文链接:https://blog.siitake.cn/nodejs-bilibili-live-3.html
本站未注明转载的文章均为原创,并采用
CC BY-NC-SA 4.0 授权协议,转载请注明来源,谢谢!
博主你好我有一台阿里云服务器centos7.3能不搭建一个这样的环境,我已经试了三天了,都能不了nodejs和npm和ffmpeg和模块等。求给出详细的教程!
其实很简单啊,nodejs、npm、ffmpeg等甚至都不用安装的,下载二进制文件后用ln链接到环境变量中就好了,至于详细教程,我抽空做吧つ﹏⊂
ffmpeg的安装需要安装x264等解码吗?直接安装目录有要求吗?
这个看您的需求了,我这里纯折腾,ffmpeg没有编译,直接用的二进制文件,至于安装目录,只要配到环境变量中,能任意目录执行即可。
我还没有找到解决的问题,crf的问题还是没找到,我哪个发错了,我写的是小写。依然说找不到crf参数,至此我又不会改代码,所以不敢轻易改动,还有就是我也换过其他版本的ffmpeg3.2.7依旧是同样的问题!会不会是服务器端口被占用或者没打开?
注释掉代码中crf那一行
[root@admin node_modules]# node my.js
[2017-08-24 15:08] Find 2 Video Files !
[2017-08-24 15:08] Vedio is Pushing !
[2017-08-24 15:08] Spawned Ffmpeg with command !
[2017-08-24 15:08] Command: ffmpeg -re -ac 2 -f concat -safe 0 -i concat.txt -i /pic/tips2.png -y -filter_complex [0:v]scale=1280:-1[video];[1:v]scale=220:-1[logo];videooverlay=x=main_w-overlay_w-15:y=15 -vcodec libx264 -preset veryfast -CRF 22 -maxrate 1000k -bufsize 3000k -acodec libmp3lame -ac 2 -ar 44100 -b:a 96k -f flv mv1.mp4
error: ffmpeg exited with code 1: Unrecognized option 'CRF'.
Error splitting the argument list: Option not found
这一步。卡主了。还有修改了你的代码,./video2我改成不带点
视频文件能读出来,命令行也可以打印,到这一步表明nodejs已经没问题了,这里是ffmpeg参数报错,我的代码中“crf”是小写,您的这个报错是大写“CRF”,请检查一下代码有咩问题,或者查一下ffmpeg文档看是否是新版本取消或变更了参数。
运行node.js出现这个了
Unrecognized option 'crf'.
Error splitting the argument list: Option not found
正常js[root@admin ~]# node
console.log("Hello World");Hello World
undefined
运行出现问题,
fs.js:856
^return binding.readdir(pathModule._makeLong(path));
Error: ENOENT: no such file or directory, scandir './video2/'
at Error (native) at Object.fs.readdirSync (fs.js:856:18) at liveON (/usr/local/lib/my.js:14:16) at Object.<anonymous> (/usr/local/lib/my.js:74:1) at Module._compile (module.js:425:26) at Object.Module._extensions..js (module.js:432:10) at Module.load (module.js:356:32) at Function.Module._load (module.js:311:12) at Function.Module.runMain (module.js:457:10) at startup (node.js:136:18)居然看到了更新
待我等会试试
你这是发生了什么,突然变成默认主题了
默认主题~ 好看啊~
试试Quark,那主题挺小的(我才不会说不到15KB呢,滑稽)
本地测试过那个~ 确实也很棒~
懒die的站长更新啦~
嗯,更新了。
香菇终于更新辣~