【疑难解决】国标GB28181协议平台EasyGBS级联上级平台采用TCP拉流视频无法播放问题分析排查

我们在进行TSINGSEE青犀视频云边端架构产品运维的时候,遇到比较多的问题是EasyGBS级联的问题,由于级联涉及到两个平台的对接,因此出现了问题总是需要更多时间进行排查。

GBS1.png

当国标平台EasyGBS级联作为下级平台,上级采用tcp拉流时,偶尔会出现播放不了的情况。其实本身EasyGBS已经支持了级联tcp拉流,但是当上级采用tcp拉流的时候,TCP拉流还是无效。

经过抓包排查发现,目前tcp级联中支持的默认模式是tcp被动的,但是有时上级发来的tcp取流消息是tcp主动的,所以导致无法播放。

66.png

67.png

因此我们需要在上级级联发送invite消息的时候从setup字段中获取是主动还是被动,然后在代码中做出区分判断。

参考代码如下:

sdp, err := sdp.ParseString(c.Req.Body)
		if err != nil {
			log.Printf("级联:回放sdp解析失败[%s]", err.Error())
			return
		}
		setup := ""
		setupAttr := sdp.Media[0].Get("setup")
		if setupAttr != nil {
			setup = setupAttr.Value
		}	
func (server *RTPUDPServer) runCCTCP() {
	addr := server.CCTCPListener.Addr()
	sms_log.Log.Printf("cc tcp server start --> %s//%s", addr.Network(), addr.String())
	var ccTCPRWriter *bufio.ReadWriter
	for !server.Stoped {
		conn, err := server.CCTCPListener.AcceptTCP()
		if err != nil {
			return
		}
		if e := conn.SetReadBuffer(server.NetworkBuffer); e != nil {
			sms_log.Log.Printf("rtp tcp conn set read buffer error, %v", e)
		}
		if e := conn.SetWriteBuffer(server.NetworkBuffer); e != nil {
			sms_log.Log.Printf("rtp tcp conn set write buffer error, %v", e)
		}
		server.CCTCPConn = conn
		ccTCPRWriter = bufio.NewReadWriter(bufio.NewReaderSize(server.CCTCPConn, server.NetworkBuffer), bufio.NewWriterSize(server.CCTCPConn, server.NetworkBuffer))
		server.ccTCPRWriter = ccTCPRWriter
	}
}

再次点击用tcp主动模式播放,发现已经有rtp流数据发送过来,也就代表视频流传输成功,视频即可正常播放。

68.png

EasyGBS的播放模式分为UDP和TCP,其中两种模式下的视频流播放也有不同的延迟,如果大家不了解的话,可以阅读《TCP及UDP区别介绍》一文简单了解一下。当然了,如果想获取更多EasyGBS相关内容的话,欢迎联系我们获取测试账号进行测试。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值