推荐一个开源流媒体工具:ZLMediaKit
推荐一个比较好用的流媒体服务开源代码:
ZLMediaKit: 实现RTSP/RTMP/HLS/HTTP协议的轻量级流媒体框架,支持大并发连接请求
https://gitee.com/xiahcu/ZLMediaKit
文章目录
- 一个基于C++11的高性能运营级流媒体服务框架
- 项目特点
- 项目定位
- 功能清单
- 其他功能细节表
- 后续任务
- 编译要求
- 编译(Linux)
- 编译(macOS)
- 编译(iOS)
- 编译(Android)
- 编译(Windows)
- 使用方法
- QA
- 参考案例
- 授权协议
- 作者联系方式
一个基于C++11的高性能运营级流媒体服务框架
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qGMRzHOl-1588662590011)(https://travis-ci.org/xiongziliang/ZLMediaKit.svg?branch=master)]
项目特点
- 基于C++11开发,避免使用裸指针,代码稳定可靠;同时跨平台移植简单方便,代码清晰简洁。
- 打包多种流媒体协议(RTSP/RTMP/HLS),支持协议间的互相转换,提供一站式的服务。
- 使用epoll+线程池+异步网络IO模式开发,并发性能优越。
- 已实现主流的的H264/H265+AAC流媒体方案,代码精简,脉络清晰,适合学习。
- 编码格式与框架代码解耦,方便自由简洁的添加支持其他编码格式
- 代码经过大量的稳定性、性能测试,可满足商用服务器项目。
- 支持linux、macos、ios、android、windows平台
- 支持画面秒开(GOP缓存)、极低延时(500毫秒内,最低可达100毫秒)
- 支持websocket-flv直播
- ZLMediaKit高并发实现原理
项目定位
- 移动嵌入式跨平台流媒体解决方案。
- 商用级流媒体服务器。
- 网络编程二次开发SDK。
功能清单
RTSP
- RTSP 服务器,支持RTMP/MP4转RTSP。
- RTSPS 服务器,支持亚马逊echo show这样的设备
- RTSP 播放器,支持RTSP代理,支持生成静音音频
- RTSP 推流客户端与服务器
- 支持
rtp over udp
rtp over tcp
rtp over http
rtp组播
四种RTP传输方式 。 - 服务器/客户端完整支持Basic/Digest方式的登录鉴权,全异步可配置化的鉴权接口。
- 支持H265编码
- 服务器支持RTSP推流(包括
rtp over udp
rtp over tcp
方式) - 支持任意编码格式的rtsp推流,只是除H264/H265+AAC外无法转协议
RTMP
- RTMP 播放服务器,支持RTSP/MP4转RTMP。
- RTMP 发布服务器,支持录制发布流。
- RTMP 播放器,支持RTMP代理,支持生成静音音频
- RTMP 推流客户端。
- 支持http-flv直播。
- 支持https-flv直播。
- 支持任意编码格式的rtmp推流,只是除H264/H265+AAC外无法转协议
HLS
- 支持HLS文件生成,自带HTTP文件服务器。
- 支持播放鉴权,鉴权结果可以缓存为cookie
HTTP[S]
- 服务器支持
目录索引生成
,文件下载
,表单提交请求
。 - 客户端提供
文件下载器(支持断点续传)
,接口请求器
,文件上传器
。 - 完整HTTP API服务器,可以作为web后台开发框架。
- 支持跨域访问。
- 支持http客户端、服务器cookie
- 支持WebSocket服务器和客户端
- 支持http文件访问鉴权
- 服务器支持
其他
- 支持输入YUV+PCM自动生成RTSP/RTMP/HLS/MP4.
- 支持简单的telnet调试。
- 支持H264的解析,支持B帧的POC计算排序。
- 支持配置文件热加载
- 支持流量统计、推流播放鉴权等事件
- 支持rtsp/rtmp/http虚拟主机
- 支持flv、mp4文件录制
- 支持rtps/rtmp协议的mp4点播,支持seek
- 支持按需拉流,无人观看自动关断拉流
- 支持先拉流后推流,提高及时推流画面打开率
- 支持rtsp/rtmp/http-flv/hls播放鉴权(url参数方式)
其他功能细节表
转协议:
功能/编码格式 H264 H265 AAC other RTSP[S] --> RTMP/HTTP[S]-FLV/FLV Y N Y N RTMP --> RTSP[S] Y N Y N RTSP[S] --> HLS Y Y Y N RTMP --> HLS Y N Y N RTSP[S] --> MP4 Y Y Y N RTMP --> MP4 Y N Y N MP4 --> RTSP[S] Y N Y N MP4 --> RTMP Y N Y N 流生成:
功能/编码格式 H264 H265 AAC other RTSP[S]推流 Y Y Y Y RTSP拉流代理 Y Y Y Y RTMP推流 Y Y Y Y RTMP拉流代理 Y Y Y Y RTP传输方式:
功能/RTP传输方式 tcp udp http udp_multicast RTSP[S] Play Server Y Y Y Y RTSP[S] Push Server Y Y N N RTSP Player Y Y N Y RTSP Pusher Y Y N N 支持的服务器类型列表
服务类型 Y/N RTSP[S] Play Server Y RTSP[S] Push Server Y RTMP Y HTTP[S]/WebSocket[S] Y 支持的客户端类型
客户端类型 Y/N RTSP Player Y RTSP Pusher Y RTMP Player Y RTMP Pusher Y HTTP[S] Y WebSocket[S] Y
后续任务
- 完善支持H265
编译要求
- 编译器支持C++11,GCC4.8/Clang3.3/VC2015或以上
- cmake3.2或以上
- 必须使用git下载完整的代码,不要使用下载zip包的方式下载源码,否则子模块代码默认不下载!你可以像以下这样操作:
git clone https://github.com/zlmediakit/ZLMediaKit.git
cd ZLMediaKit
git submodule update --init
编译(Linux)
我的编译环境
- Ubuntu16.04 64 bit + gcc5.4
- cmake 3.5.1
编译
//如果是centos6.x,需要先安装较新版本的gcc以及cmake,然后打开脚本build_for_linux.sh手动编译//如果是ubuntu这样的比较新的系统版本可以直接操作第4步1、安装GCC5.2(如果gcc版本高于4.7可以跳过此步骤)sudo yum install centos-release-scl -ysudo yum install devtoolset-4-toolchain -yscl enable devtoolset-4 bash2、安装cmake#需要安装新版本cmake,当然你也可以通过yum或者apt-get方式安装(前提是版本够新)tar -xvf cmake-3.10.0-rc4.tar.gzcd cmake-3.10.0-rc4./configuremake -j4sudo make install3、切换高版本gccscl enable devtoolset-4 bash4、编译cd ZLMediaKit./build_for_linux.sh
编译(macOS)
我的编译环境
- macOS Sierra(10.12.1) + xcode8.3.1
- Homebrew 1.1.3
- cmake 3.8.0
编译
cd ZLMediaKit ./build_for_mac.sh
编译(iOS)
编译环境:
请参考macOS的编译指导。
编译
cd ZLMediaKit ./build_for_ios.sh
你也可以生成Xcode工程再编译:
cd ZLMediaKit mkdir -p build cd build # 生成Xcode工程,工程文件在build目录下 cmake .. -DCMAKE_TOOLCHAIN_FILE=../cmake/iOS.cmake -DIOS_PLATFORM=SIMULATOR64 -G "Xcode"
编译(Android)
我的编译环境
- macOS Sierra(10.12.1) + xcode8.3.1
- Homebrew 1.1.3
- cmake 3.8.0
- android-ndk-r14b
编译
cd ZLMediaKit export ANDROID_NDK_ROOT=/path/to/ndk ./build_for_android.sh
编译(Windows)
我的编译环境
- windows 10
- visual studio 2017
- cmake-gui
编译
1 进入ZLMediaKit目录执行 git submodule update --init 以下载ZLToolKit的代码2 使用cmake-gui打开工程并生成vs工程文件.3 找到工程文件(ZLMediaKit.sln),双击用vs2017打开.4 选择编译Release 版本.5 找到目标文件并运行测试用例.
使用方法
作为服务器:
TcpServer::Ptr rtspSrv(new TcpServer()); TcpServer::Ptr rtmpSrv(new TcpServer()); TcpServer::Ptr httpSrv(new TcpServer()); TcpServer::Ptr httpsSrv(new TcpServer());rtspSrv->start<RtspSession>(mINI::Instance()[Config::Rtsp::kPort]); rtmpSrv->start<RtmpSession>(mINI::Instance()[Config::Rtmp::kPort]); httpSrv->start<HttpSession>(mINI::Instance()[Config::Http::kPort]); httpsSrv->start<HttpsSession>(mINI::Instance()[Config::Http::kSSLPort]);
作为播放器:
MediaPlayer::Ptr player(new MediaPlayer()); weak_ptr<MediaPlayer> weakPlayer = player; player->setOnPlayResult([weakPlayer](const SockException &ex) {InfoL << "OnPlayResult:" << ex.what();auto strongPlayer = weakPlayer.lock();if (ex || !strongPlayer) {return;}auto viedoTrack = strongPlayer->getTrack(TrackVideo);if (!viedoTrack) {WarnL << "没有视频Track!";return;}viedoTrack->addDelegate(std::make_shared<FrameWriterInterfaceHelper>([](const Frame::Ptr &frame) {//此处解码并播放})); });player->setOnShutdown([](const SockException &ex) {ErrorL << "OnShutdown:" << ex.what(); });//支持rtmp、rtsp (*player)[Client::kRtpType] = Rtsp::RTP_TCP; player->play("rtsp://admin:jzan123456@192.168.0.122/");
作为代理服务器:
//support rtmp and rtsp url //just support H264+AAC auto urlList = {"rtmp://live.hkstv.hk.lxdns.com/live/hks","rtsp://184.72.239.149/vod/mp4://BigBuckBunny_175k.mov"}; map<string , PlayerProxy::Ptr> proxyMap; int i=0; for(auto url : urlList){//PlayerProxy构造函数前两个参数分别为应用名(app),流id(streamId)//比如说应用为live,流id为0,那么直播地址为://http://127.0.0.1/live/0/hls.m3u8//rtsp://127.0.0.1/live/0//rtmp://127.0.0.1/live/0//录像地址为://http://127.0.0.1/record/live/0/2017-04-11/11-09-38.mp4//rtsp://127.0.0.1/record/live/0/2017-04-11/11-09-38.mp4//rtmp://127.0.0.1/record/live/0/2017-04-11/11-09-38.mp4PlayerProxy::Ptr player(new PlayerProxy("live",to_string(i++).data()));player->play(url);proxyMap.emplace(string(url),player); }
作为推流客户端器:
PlayerProxy::Ptr player(new PlayerProxy("app","stream")); //拉一个流,生成一个RtmpMediaSource,源的名称是"app/stream" //你也可以以其他方式生成RtmpMediaSource,比如说MP4文件(请研读MediaReader代码) player->play("rtmp://live.hkstv.hk.lxdns.com/live/hks");RtmpPusher::Ptr pusher; //监听RtmpMediaSource注册事件,在PlayerProxy播放成功后触发。 NoticeCenter::Instance().addListener(nullptr,Config::Broadcast::kBroadcastRtmpSrcRegisted,[&pusher](BroadcastRtmpSrcRegistedArgs){//媒体源"app/stream"已经注册,这时方可新建一个RtmpPusher对象并绑定该媒体源const_cast<RtmpPusher::Ptr &>(pusher).reset(new RtmpPusher(app,stream));//推流地址,请改成你自己的服务器。//这个范例地址(也是基于mediakit)是可用的,但是带宽只有1mb,访问可能很卡顿。pusher->publish("rtmp://jizan.iok.la/live/test"); });
QA
怎么测试服务器性能?
ZLMediaKit提供了测试性能的示例,代码在tests/test_benchmark.cpp。
这里是测试报告:benchmark.md
github下载太慢了,有其他下载方式吗?
你可以在通过开源中国获取最新的代码,地址为:
ZLToolKit
ZLMediaKit
在windows下编译很多错误?
由于本项目主体代码在macOS/linux下开发,部分源码采用的是无bom头的UTF-8编码;由于windows对于utf-8支持不甚友好,所以如果发现编译错误请先尝试添 加bom头再编译。
也可以通过参考这篇博客解决:
vs2015:/utf-8选项解决UTF-8 without BOM 源码中文输出乱码问题
参考案例
IOS摄像头实时录制,生成rtsp/rtmp/hls/http-flv
IOS rtmp/rtsp播放器,视频推流器
支持linux、windows、mac的rtmp/rtsp播放器
上述工程可能在最新的代码的情况下编译不过,请手动修改
授权协议
本项目自有代码使用宽松的MIT协议,在保留版权信息的情况下可以自由应用于各自商用、非商业的项目。
但是本项目也零碎的使用了一些其他的开源代码,在商用的情况下请自行替代或剔除;
由于使用本项目而产生的商业纠纷或侵权行为一概与本项项目及开发者无关,请自行承担法律风险。
作者联系方式
- 邮箱:771730766@qq.com(本项目相关或流媒体相关问题请走issue流程,否则恕不邮件答复)
- QQ群:542509000
我的微信公众号(不是流媒体作者哦):
推荐一个开源流媒体工具:ZLMediaKit相关推荐
- 推荐一个开源的任务管理工具DooTask(支持私有部署)
原文出处:https://www.yundashi168.com/382.html 今天老逛推荐一个开源的任务管理工具DooTask,该工具会提供各类文档协作功能.在线思维导图.在线流程图.项目管理. ...
- 推荐一个开源的任务管理工具
往期热门文章: 1.妙用Java 8中的 Function接口 消灭if...else... 2.1 平方厘米在元宇宙卖到 14 万?单价比北京学区房贵多了! 3.干掉visio,这个画图神器真的绝了 ...
- 推荐一个开源文件管理系统,简单好用
大家好,我是为广大程序员兄弟操碎了心的小编,每天推荐一个小工具/源码,装满你的收藏夹,每天分享一个小技巧,让你轻松节省开发效率,实现不加班不熬夜不掉头发,是我的目标! 今天小编推荐一个开源文件 ...
- 推荐一个开源的区块链开发者工具网站
开源区块链开发者工具箱 https://ChainTool.tech 今天可以正式上线了.ChainTool 使用完全开源的方式编写一些开发者日常经常使用的工具. 关于 ChainToolDAO 大约 ...
- 推荐一个工作流自动化工具
以下文章来源方志朋的博客,回复"666"获面试宝典 今天,要和大家分享一个"开源"工作流自动化工具--n8n ,简单来说,它是一个与其他应用程序集成的应用程序, ...
- 推荐一个开源文本识别工具箱,实现 5 种实用经典算法
推荐一个由52CV群友 @chibohe 开发的文本识别工具箱,其基于Pytorch 使用统一的方式重新实现了一系列经典的场景文本识别论文. 代码在这里: https://github.com/chi ...
- 推荐一个开源免费的绘图软件 Draw.io 可导出矢量图
问题描述 关于绘图,微软的 Visio 是一个不错的选择,但是不支持 mac 下使用,不支持 linux 桌面系统,而且是一个收费的软件. 推荐一个免费的软件,官网地址为 draw.io,先不急着下载 ...
- 推荐一个git辅助工具:TortoiseGit
对于很多不熟悉git命令的朋友来说,使用git命令行操作简直太难了. 这里我们推荐一个辅助工具,TortoiseGit,它可以把一些常用的git操作转换为可视化操作,让你不用再记忆大量git命令. T ...
- 看腻了数字,拼图验证码?推荐一个开源项目——把验证码设计成射击游戏
一.导读 生活中我们见到的大多数验证方式都是以下这样的: 这些都太普通了,可不可以用小游戏来验证呢? 今天在GitHub上看到一个开源项目--doom captcha 二.效果预览 作者非常有创意的将 ...
最新文章
- 多变异位自适应遗传算法(MMAdapGA)的算法原理、算法步骤和matlab实现
- linux下定时清理磁盘日志步骤
- input标签获取图片文件尺寸
- GIMP - GNU 图像处理程序 用户手册
- element vue 纵向滑动条_Vue 部分
- 今天看到一个热搜,说一个美团会员配送费6元,普通用户2元,导致轩然大波
- 项目管理工具Redmine各功能测试
- JCreator使用技巧
- linux libxml2编译,libxml2 ARM 交叉编译
- python猜字游戏猜三次_python的猜数字游戏
- 北斗卫星广播星历计算卫星位置
- dtech串口驱动 linux,帝特USB转串口驱动
- 计算机word文档无法工作,教您电脑word打不开怎么办
- 运维团队(OPS)与技术团队有效沟通配合探讨
- 浅谈中国现货市场环境对期货市场发展的影响
- 大数据解析:程序员到底能干到多少岁?
- 德威控股在港交所招股书失效:2021年度利润大增,由杨时家族控股
- 怎么给网页加动态背景
- 关于最小二乘估计的一点理解和感悟
- Irvue for Mac(壁纸软件)
热门文章
- 解决CAA百科全书中search无法加载的问题。
- 智能开关面板行业概览
- Zabbix监控系统系列之二 : 初始化配置
- 关于“好奇号”火星车(Rover)的核电池
- 每日一句API接口,免费好用
- 什么软件可以用twitch_什么是Twitch Studio,您是否应该使用它进行流式传输?
- 动画版雪碧_雪碧动画:老板凯蒂
- 什么叫CODE BEHIND
- 百度“AI 宣言”:开发者是推动人类进步的最伟大力量
- python爬网站的题库_Python零基础爬虫教程(实战案例爬取电影网站资源链接)