RTSP/GB28181/Ehome协议/HIKSDK视频融合共享平台EasyCVR级联到上级国标平台在线状态不更新修复
支持RTSP、GB28181、SDK、Ehome协议的视频平台EasyCVR支持将所有视频通道通过GB28181协议级联到上级国标平台上,且支持同一通道级联到多个上级平台,这一操作给很多用户的级联带来了便捷。
但是EasyCVR在1.0.34的版本当中,EasyCVR级联到国标平台,下级平台显示上级平台在线状态时状态更新异常。
EasyCVR中上级平台的在线状态更新是由定时器完成,通过国标协议中心跳包去判断上级平台的状态,但是只在上级平台在线时才进行检测,如果出现网络问题,上级平台状态为离线后,不会去定时检测。当网络恢复正常,Easycvr中的上级平台状态无法恢复。
因此我么可以通过修复判断规则修复该问题,参考代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | func (c *Client) StartKeepAlive() { defer func() { if err := recover(); err != nil { err_logger.Error(fmt.Sprintf( "%s\n" , err)) err_logger.Error(fmt.Sprintln( string (debug.Stack()))) } }() timer := time.NewTicker(time.Duration(c.Cascade.KeepaliveInterval) * time.Second) defer timer.Stop() for !c.Stoped { select { case <-timer.C: c.doKeepAlive() case <-c.KeepAliveQuit: c.ClientOnline( false ) log.Println( "级联保活停止:" , c.Cascade.ID) return } } } func (c *Client) doKeepAlive() { req, _, err := c.MakeKeepAliveRequest(c.LocalSerial, c.Cascade.Realm) if err != nil { log.Println( "级联心跳包组包失败" ) return } err = req.SendByTransport(c.Transport) if err != nil { log.Println( "级联心跳包发送失败" , err.Error()) return } log.Println( "级联保活:" , c.Cascade.ID) res, err := c.WaitAck(req.HeaderMap[ "Call-ID" ], req.HeaderMap[ "CSeq" ]) if err != nil { c.ClientOnline( false ) return } if res.StatusCode != 200 { c.ClientOnline( false ) return } else { c.ClientOnline( true ) } } |
分类:
EasyCVR
【推荐】国内首个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 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 提示词工程——AI应用必不可少的技术
· 地球OL攻略 —— 某应届生求职总结
· 字符编码:从基础到乱码解决
· SpringCloud带你走进微服务的世界