首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >EasyGBS新内核版本摄像头流量统计为零的优化方案

EasyGBS新内核版本摄像头流量统计为零的优化方案

原创
作者头像
TSINGSEE青犀视频
修改2021-09-10 17:46:34
修改2021-09-10 17:46:34
24200
代码可运行
举报
文章被收录于专栏:TSINGSEE青犀视频TSINGSEE青犀视频
运行总次数:0
代码可运行

EasyGBS的部分项目现场是具有摄像头直播流量统计功能的,在某项目中,我们发现EasyGBS通道直播正常的情况下;所有摄像头的直播流量上下行均为零后发现公网也存在此问题。

此问题仅出现在EasyGBS的新内核版本里,因此判断为新内核版本EasyGBS该功能并未实现。查看功能模块代码发现老版本内核的流量统计,是由Go后端定时访问nginx的获取流量统计接口得到数据,新内核丢弃了nginx,这也证实了该功能确实未实现。

resp, err := client.Get(fmt.Sprintf(“http://127.0.0.1:%d/getlivesessions”, GetHTTPPort()))

根据新内核官方API文档,发现新内核也拥有流量统计接口暴露,因此可以通过此接口获取到对应通道的上下行流量信息。

Golang json格式展示:

代码语言:javascript
代码运行次数:0
运行
复制
type AllGroup struct {
   ErrorCode int    `json:"error_code"`
   Desp      string `json:"desp"`
   Data      struct {
      Groups []struct {
         StreamName  string `json:"stream_name"`
         AudioCodec  string `json:"audio_codec"`
         VideoCodec  string `json:"video_codec"`
         VideoWidth  int    `json:"video_width"`
         VideoHeight int    `json:"video_height"`
         Pub         struct {
            Protocol      string `json:"protocol"`
            SessionId     string `json:"session_id"`
            RemoteAddr    string `json:"remote_addr"`
            StartTime     string `json:"start_time"`
            ReadBytesSum  int64  `json:"read_bytes_sum"`
            WroteBytesSum int64  `json:"wrote_bytes_sum"`
            Bitrate       int    `json:"bitrate"`
            ReadBitrate   int    `json:"read_bitrate"`
            WriteBitrate  int    `json:"write_bitrate"`
         } `json:"pub"`
         Subs []struct {
            Protocol      string `json:"protocol"`
            SessionId     string `json:"session_id"`
            RemoteAddr    string `json:"remote_addr"`
            StartTime     string `json:"start_time"`
            ReadBytesSum  int64  `json:"read_bytes_sum"`
            WroteBytesSum int64  `json:"wrote_bytes_sum"`
            Bitrate       int    `json:"bitrate"`
            ReadBitrate   int    `json:"read_bitrate"`
            WriteBitrate  int    `json:"write_bitrate"`
         } `json:"subs"`
         Pull struct {
            Protocol      string `json:"protocol"`
            SessionId     string `json:"session_id"`
            RemoteAddr    string `json:"remote_addr"`
            StartTime     string `json:"start_time"`
            ReadBytesSum  int64  `json:"read_bytes_sum"`
            WroteBytesSum int64  `json:"wrote_bytes_sum"`
            Bitrate       int    `json:"bitrate"`
            ReadBitrate   int    `json:"read_bitrate"`
            WriteBitrate  int    `json:"write_bitrate"`
         } `json:"pull"`
      } `json:"groups"`
   } `json:"data"`
}

部分代码:

代码语言:javascript
代码运行次数:0
运行
复制
func GetLiveSessions(port string) (sessions []*SessionInfo) {
   sessions = make([]*SessionInfo, 0)
   defer func() {
      if p := recover(); p != nil {
         log.Println(p)
      }
   }()
   client := http.Client{
      Timeout: 3 * time.Second,
   }
   resp, err := client.Get(fmt.Sprintf("http://127.0.0.1:%s/api/stat/all_group", port))
   if err != nil {
      return
   }
   defer resp.Body.Close()
   body, err := ioutil.ReadAll(resp.Body)
   if err != nil {
      return
   }
   var allGourp AllGroup
   err = json.Unmarshal(body, &allGourp)
   if err != nil {
      return
   }
   for _, v := range allGourp.Data.Groups {
      strs := strings.Split(v.StreamName, "_")

      var worteSum int64
      for _, s := range v.Subs {
         if s.WroteBytesSum != 0 {
            worteSum += s.WroteBytesSum
         }
      }
      if len(strs) < 3 || (v.Pub.ReadBytesSum == 0 && worteSum == 0) {
         continue
      }
      sessions = append(sessions, &SessionInfo{
         ID:       fmt.Sprintf("%s_%s", strs[0], strs[1]),
         InBytes:  v.Pub.ReadBytesSum,
         OutBytes: worteSum,
      })
   }
   return
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档