最近帮朋友的公司部署了一套分流+水印的直播系统
顺手打包成 docker 镜像,方便大家需要用到的时候开箱即用,不需要百度一些零碎的文章 也可做简单的直播服务,只需调整配置文件便可达到你的需求.
需求:将直播流分流到两个云厂商的直播云,一个有水印,一个无水印。使用 hls 播放
朋友需求的拓扑示意图:
当前拓扑示意图(阿里云和腾讯云不方便放出推流和拉流地址,有兴趣的同学可以去申请玩一下)
基于docker-nginx-rtmp进行配置部署,这篇文章的意义是实现直播分流及直播画面水印.
$ yum -y install docker #安装 docker $ systemctl enable docker #配置开机启动 $ systemctl start docker #启动 docker 服务
#如果速度慢可使用阿里云:docker pull registry.cn-shenzhen.aliyuncs.com/ar414/nginx-rtmp-ffmpeg:v1 $ docker pull ar414/nginx-rtmp-ffmpeg $ docker run -it -d -p 1935:1935 -p 8080:80 --rm ar414/nginx-rtmp-ffmpeg
rtmp://<server ip>:1935/stream/$STREAM_NAME
将证书复制到容器内,并在容器内修改 nginx.conf 配置文件,然后重新 commit (操作容器内的文件都需要重新 commit 才会生效)
#/etc/nginx/nginx.conf listen 443 ssl; ssl_certificate /opt/certs/example.com.crt; ssl_certificate_key /opt/certs/example.com.key;
Custom Streaming Server
rtmp://<server ip>:1935/stream
HLS 播放测试工具: http://player.alicdn.com/aliplayer/setting/setting.html (如果配置了证书则使用 https )
RTMP 测试工具:PotPlayer
rtmp { server { listen 1935; #端口 chunk_size 4000; #RTMP 直播流配置 application stream { live on; #添加水印及分流,这次方便测试直接分流到当前服务器 hls #实际生产一般都分流到直播云(腾讯云、阿里云、ucloud ) #只需把需要分流的地址替换即可 #有水印:rtmp://localhost:1935/hls/$name_wm #无水印:rtmp://localhost:1935/hls/$name exec ffmpeg -i rtmp://localhost:1935/stream/$name -i /opt/images/ar414.png -filter_complex "overlay=10:10,split=1[ar414]" -map '[ar414]' -map 0:a -s 1920x1080 -c:v libx264 -c:a aac -g 30 -r 30 -tune zerolatency -preset veryfast -crf 23 -f flv rtmp://localhost:1935/hls/$name_wm -c:a libfdk_aac -b:a 128k -c:v libx264 -b:v 2500k -f flv -g 30 -r 30 -s 1920x1080 -preset superfast -profile:v baseline rtmp://localhost:1935/hls/$name; } application hls { live on; hls on; hls_fragment 5; hls_path /opt/data/hls; } } }
application stream { live on; #分流至本机 hls exec ffmpeg -i rtmp://localhost:1935/stream/$name -i /opt/images/ar414.png -filter_complex "overlay=10:10,split=1[ar414]" -map '[ar414]' -map 0:a -s 1920x1080 -c:v libx264 -c:a aac -g 30 -r 30 -tune zerolatency -preset veryfast -crf 23 -f flv rtmp://localhost:1935/hls/$name_wm -c:a libfdk_aac -b:a 128k -c:v libx264 -b:v 2500k -f flv -g 30 -r 30 -s 1920x1080 -preset superfast -profile:v baseline rtmp://localhost:1935/hls/$name; #分流至腾讯云 exec ffmpeg -i rtmp://localhost:1935/stream/$name -i /opt/images/ar414.png -filter_complex "overlay=10:10,split=1[ar414]" -map '[ar414]' -map 0:a -s 1920x1080 -c:v libx264 -c:a aac -g 30 -r 30 -tune zerolatency -preset veryfast -crf 23 -f flv rtmp://live-push.tencent.com/stream/$name_wm -c:a libfdk_aac -b:a 128k -c:v libx264 -b:v 2500k -f flv -g 30 -r 30 -s 1920x1080 -preset superfast -profile:v baseline rtmp://live-push.tencent.com/stream/$name; #分流至阿里云 exec ffmpeg -i rtmp://localhost:1935/stream/$name -i /opt/images/ar414.png -filter_complex "overlay=10:10,split=1[ar414]" -map '[ar414]' -map 0:a -s 1920x1080 -c:v libx264 -c:a aac -g 30 -r 30 -tune zerolatency -preset veryfast -crf 23 -f flv rtmp://live-push.aliyun.com/stream/$name_wm -c:a libfdk_aac -b:a 128k -c:v libx264 -b:v 2500k -f flv -g 30 -r 30 -s 1920x1080 -preset superfast -profile:v baseline rtmp://live-push.aliyun.com/stream/$name; }
水印位置
| 水印图片位置 | overlay 值 | | ---- | ---- | | 左上角 | 10:10 | | 右上角 | main_w-overlay_w-10:10 | | 左下角 | 10:main_h-overlay_h-10 | | 右下角 | main_w-overlay_w-10 : main_h-overlay_h-10 |
overlay 参数
| 参数 | 说明 | | ---- | ---- | | main_w | 视频单帧图像宽度(当前配置文件 1920 ) | | main_h | 视频单帧图像高度(当前配置文件 1080 ) | | overlay_w | 水印图片的宽度 | | overlay_h | 水印图片的高度 |
1 HTSdTt3WygdgQQGe 2020-03-17 18:14:07 +08:00 via Android 不错,收藏 |
![]() | 2 ar414 OP 为啥我发到 nginx 节点 会跑到提问这,奇了个怪 |
![]() | 4 npe 2020-03-17 18:36:34 +08:00 直播主要是流量和带宽,不如直接用各厂大解决方案。 |
5 MeteorCat 2020-03-17 18:39:08 +08:00 via Android 我记得很容易断,很不稳定 |
9 MonoLogueChi 2020-03-17 19:55:42 +08:00 via Android 这种情况直接 SRS 就可以,以前也是自己编译 nginx,后来搞得烦了,直接留一份二进制文件,再后来留的那份二进制文件找不到了,就直接 SRS 了 |
![]() | 11 cctv6 2020-03-18 09:07:10 +08:00 via iPhone 第一次见到这种操作 |
![]() | 12 npe 2020-03-18 10:42:17 +08:00 @ar414 我的意思是 nginx 服务器需要较高的配置来支撑,随之的成本也就很高,那既然商用为什么不一步到位上大厂的直播解决方案省时省力。。 (如果只是学习的话当我没说) |
13 garychang 2020-06-17 14:49:26 +08:00 不错,收藏 |