默默前行的livego--基于go语言的rtmp直播服务器
为什么go语言,原因太多了!
- 轻量级协程,随时goroutine
- 方便的channel
- 方便的interface
- 强大的服务器性能
简单点GO语言---为服务器而生!
我们来看看: livego--基于go语言的rtmp直播服务器
github地址: https://github.com/runner365/livego
什么是livego
livego是基于golang开发的rtmp服务器
为什么基于golang
-
golang在语言基本支持多核CPU均衡使用,支持海量轻量级线程,提高其并发量
当前开源的缺陷:- srs只能运行在一个单核下,如果需要多核运行,只能启动多个srs监听不同的端口来提高并发量;
- ngx-rtmp启动多进程后,报文在多个进程内转发,需要二次开发,否则静态推送到多个子进程,效能消耗大;
golang在语言级别解决了上面多进程并发的问题。
-
二次开发简洁快速
golang的开发效率远远高过C/C++
livego支持哪些特性
- rtmp 推流,拉流
- 支持hls观看
- 支持http-flv观看
- 支持gop-cache缓存
- 静态relay支持:支持静态推流,拉流(支持对rtmp/http-flv拉流)
- 动态replay支持:支持http动态控制拉流、推流
- 支持push,push_done事件的外挂进程启动
- 统计信息支持:支持http在线查看流状态
livego性能有多强
go语言为服务器性能而生,看看性能有多强吧!
测试机型:阿里云32核64G独享服务器
测试方法:
- 用ffmpeg向livego的rtmp服务推流:ffmpeg -re -i source.200kbps.768x320.flv -c copy -f flv rtmp://10.111.59.49/live/stream
- 启动3个sb_rtmp_load的拉流进程,每个进程拉流10000路
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探