如何解决国标GB28181协议EasyGBS视频平台CPU占用过高的情况?
CPU(中央处理器)作为计算机系统的运算和控制核心,是信息处理、程序运行的最终执行单元。之前我们解决过TSINGSEE青犀视频云边端架构中国标平台EasyGBS播放H265编码视频后CPU过高的问题(EasyGBS播放H.265编码如何降低CPU来增加视频传输效率),大家可以了解一下。
在正常情况下,只有视频播放的负荷超过了处理器的负荷,才会出现CPU过高的提示,但是在我们做easygbs1.4.4版本的时候,发现一个很奇怪的现象,就是平台没有视频在播放,但是出现cpu占用过高的情况。
经过TSINGSEE青犀视频研发团队的排查分析,发现是handleTCPConnection这个函数占用过高。
进一步排查后发现在handleTCPConnection中,每次tcp读取错误的时候都会创建新的slice来重新读取,导致内容复杂,处理器负荷过大,出现CPU占用过高的问题。
因此我们可以将slice的创建放在读取tcp消息之前,一个链接只用一个slice,减少资源占用。参考代码如下:
1 2 3 4 5 6 7 8 | sipBytes := make([] byte , UDP_BUF_SIZE) for !server.Stoped { n, err := con.Read(sipBytes) if err != nil { log.Printf( "read tcp sip bytes error, %v" , err) con.Close() break } |
再次接入则显示一切正常。
EasyGBS视频平台只是TSINGSEE青犀视频云边端架构产品中的一个服务,更多视频解决方案可以联系我们了解,我们均为大家提供了试用版本,欢迎大家进行测试。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结