随笔 - 936  文章 - 0  评论 - 3  阅读 - 30万

国标GB/T28181流媒体服务器EasyGBS修复TCP模式下视频流保活导致程序崩溃的问题

我们的国标GB28181流媒体服务器输出视频,有两种模式进行传输:UDP和TCP,UDP的传输虽然快,但是容易丢包,TCP的传输虽然稳定可靠,但也比较容易占用资源,用户可以根据自己的需要来选择传输协议。

一般情况下,我们在发布国标流媒体服务器的新版本之前,会对版本各个细节的兼容性进行测试,本文依旧是在测试过程中发现的报错问题。

EasyGBS使用TCP拉流报runtime error

近期在云平台服务器上测试发现,EasyGBS在TCP拉流时,运行一段时间后会崩溃的问题,查看日志,发现报错:

    panic: runtime error: invalid memory address or nil pointer dereference
    [signal 0xc0000005 code=0x1 addr=0x38 pc=0xaeacc8]
    
    goroutine 13078 [running]:
    gitee.com/easydarwin/EasyGBSGo/sms/uas.(*MediaSession).Keepalive(0xc00190a9a0)
    	D:/Golang/own/src/gitee.com/easydarwin/EasyGBSGo/sms/uas/media_session.go:112 +0x288
    created by gitee.com/easydarwin/EasyGBSGo/sms/uas.HandleInvite
    	D:/Golang/own/src/gitee.com/easydarwin/EasyGBSGo/sms/uas/handle_invite.go:257 +0x15bc
    panic: runtime error: invalid memory address or nil pointer dereference
    [signal 0xc0000005 code=0x1 addr=0x38 pc=0xaeacc8]

分析问题

经过查看代码,分析发现,在tcp模式下流保活仍采用的udpserver服务进行保活数据记录,而此时的udpserver还未开启,以致指针越界发生未知的错误,从而导致程序崩溃。

解决问题

我们在此做了个流保活数据记录处理,可成功解决这类问题,代码如下,供大家参考:

 	if stream.Cascade != "" {

		if msess.MediaTransport == "TCP" {

			if msess.RTPTCPServer != nil {

				msess.RTPTCPServer.Cascade = stream.Cascade

			}

		}else {

			if msess.RTPUDPServer != nil {

				msess.RTPUDPServer.Cascade = stream.Cascade

			}

		}

	}

posted on   EasyGBS  阅读(548)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结
< 2025年3月 >
23 24 25 26 27 28 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 1 2 3 4 5

点击右上角即可分享
微信分享提示