海康摄像头 + M7s(Monibuca) + FFmpeg + Python实现多个网络摄像头视频流推流

最近在研究流媒体服务器时,我注意到了一款开源软件------M7s。按照官网的指南部署完成后,我开始进行测试,发现单视频流推送非常顺利,没有任何问题。然而,当我尝试进行多视频流推送时,却发现网上的相关教程寥寥无几,即便找到了一些,也大多与我的需求不完全匹配。面对这种情况,我决定自己动手编写代码来实现多视频流的推送。这样不仅能精准满足我的需求,也能在这个过程中加深对流媒体技术的理解。希望这段探索能为我的项目带来新的突破。

由于python开发脚本方便,便选择了python。视频处理属于CPU密集型任务,使用多进程(multiprocessing)更加匹配任务需求。

一、必要的包

python 复制代码
import subprocess
import multiprocessing

subprocess 负责调用ffmpeg的shell命令
multiprocessing 负责调用CPU开启多进程,避开GIL锁

二、monibuca视频流格式

根据官网的格式要求,进行ffmpeg命令编写

shell 复制代码
ffmpeg -i {input_url} -c:v libx264 -c:a aac -f rtsp {output_url}

input_url为你的视频流地址,我的是海康网络摄像头,格式是

powershell 复制代码
rtsp://admin:pwd@摄像头ip/h264/ch1/sub/av_stream

output_url地址按照monibuca官网要求格式为

powershell 复制代码
rtsp://localhost/app_name/ip_name}

app_name 和 ip_name 根据自己要求设置,不能重复

三、核心代码

subprocess部分

python 复制代码
def push_stream(ip_address,srs_server,app_name,i):
	command = f"ffmpeg -i {input_url} -c:v libx264 -c:a aac -f rtsp {output_url}"
	process = subprocess.Popen(command, stdout=subprocess.PIPE, stderr=subprocess.PIPE)    
	stdout, stderr = process.communicate()

multiprocessing部分

python 复制代码
if __name__ == "__main__":
    processes = []
	for i in range(0,len(ip_info)):
	        ip_address = f"{ip_info[i]}"
	        p = multiprocessing.Process(target=push_stream, args=(ip_address,srs_server,app_name,i))
	        processes.append(p)
	        p.start()

四、运行程序

成功,我这只是使用了四个测试摄像头

相关推荐
星哥说事10 分钟前
网络自动化:Ansible/Netmiko 网络设备批量配置与管理
网络·自动化·ansible
追风少年ii15 分钟前
脚本更新--CosMx、Xenium的邻域通讯分析(R版本)
linux·python·r语言·r·单细胞·培训
iteye_993918 分钟前
Pycharm(社区办)安装(Window操作系统)
python
qq_4798754335 分钟前
Five RFCs
网络
海星船长丶44 分钟前
Chrony服务器同步时间服务器实验
运维·服务器
Ronin3051 小时前
【Linux网络】定制协议
linux·网络·协议·序列化和反序列化·定制协议·tcp网络通信
cliproxydaili1 小时前
Cliproxy与Adspower指纹浏览器:跨境业务安全与效率的双重引擎
运维·服务器·安全
闲人编程1 小时前
Python设计模式实战:用Pythonic的方式实现单例、工厂模式
开发语言·python·单例模式·设计模式·工厂模式·codecapsule·pythonic
byte轻骑兵2 小时前
医疗信创标杆实践:浙人医 LIS 系统异构多活容灾架构深度解析(附 KingbaseES 实战)
网络·架构·1024程序员节
西门吹雪@1322 小时前
局域网手机/平板无数据线传输文件-通过网络传输LocalSend
网络·智能手机·电脑