飞道的博客

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

576人阅读  评论(0)

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

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

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

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

参考代码如下:


  
  1. sdp, err := sdp.ParseString(c.Req.Body)
  2. if err != nil {
  3. log.Printf( "级联:回放sdp解析失败[%s]", err.Error())
  4. return
  5. }
  6. setup := ""
  7. setupAttr := sdp.Media[ 0].Get( "setup")
  8. if setupAttr != nil {
  9. setup = setupAttr.Value
  10. }

  
  1. func ( server *RTPUDPServer) runCCTCP() {
  2. addr := server.CCTCPListener.Addr()
  3. sms_log. Log.Printf( "cc tcp server start --> %s//%s", addr.Network(), addr. String())
  4. var ccTCPRWriter *bufio.ReadWriter
  5. for ! server.Stoped {
  6. conn, err := server.CCTCPListener.AcceptTCP()
  7. if err != nil {
  8. return
  9. }
  10. if e := conn.SetReadBuffer( server.NetworkBuffer); e != nil {
  11. sms_log. Log.Printf( "rtp tcp conn set read buffer error, %v", e)
  12. }
  13. if e := conn.SetWriteBuffer( server.NetworkBuffer); e != nil {
  14. sms_log. Log.Printf( "rtp tcp conn set write buffer error, %v", e)
  15. }
  16. server.CCTCPConn = conn
  17. ccTCPRWriter = bufio.NewReadWriter(bufio.NewReaderSize( server.CCTCPConn, server.NetworkBuffer), bufio.NewWriterSize( server.CCTCPConn, server.NetworkBuffer))
  18. server.ccTCPRWriter = ccTCPRWriter
  19. }
  20. }

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

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


转载:https://blog.csdn.net/EasyGBS/article/details/109454233
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场