EasyGBS在网页流量统计的地方出现统计不准的问题优化
2023-04-18 15:03:37 时间
EasyGBS视频平台在去年研发了不少的功能更新,比如告警功能、语音对讲等。今年也在持续对这些功能进行各项适配性的测试,目前我们也在开发一些智能分析相关的服务,如果大家有兴趣可以关注我们的博客,我们将不定期在博客内分享我们的开发经验。
近期我们发现EasyGBS在网页流量统计的地方出现统计不准的现象,要解决这个问题,首先去数据库查看数据是否正确,然后我们看到,每次增加的流量数据,发现在观看人数相同的情况下流量每次增长的幅度都不一样。
添加如下代码,后台在统计流量的时候,首先按照时间排序,然后查询出最新一次的流量记录数据,然后再与当前的流量进出数据对比,最后将差值存入到数据库中。
for _, sess := range dss.GetLiveSessions(mediaserver.GetApiPort()) {
idArr := strings.Split(sess.ID, "_")
device_id := idArr[0]
channel_id := idArr[1]
channelDataMode := models.ChannelData{}
channelDataCount := 0
dbclient.Where("device_id = ? and channel_id = ?", device_id, channel_id).Order("create_time desc").Take(&channelDataMode)
dbclient.Model(models.ChannelData{}).Where("device_id = ? and channel_id = ?", device_id, channel_id).Order("create_time desc").Count(&channelDataCount)
channelDataMode.DeviceID = device_id
channelDataMode.ChannelID = channel_id
channelDataMode.UpdateTime = time.Now()
channelDataMode.CreateTime = time.Now()
再次播放一会查看流量数据显示正常:
相关文章
- 直接在代码里面对list集合进行分页
- .NET Framework 4.5新特性详解
- 大数据的简要介绍
- 大数据的由来
- 高斯混合模型的自然梯度变量推理
- timing-wheel 仿Kafka实现的时间轮算法
- 使用Navicat软件连接自建数据库(Linux系统)
- 那一天,我被Redis主从架构支配的恐惧
- Redis 深入了解键的过期时间
- C#使用委托调用实现用户端等待闪屏
- 基于流计算 Oceanus 和 Elasticsearch Service 构建百亿级实时监控系统
- GRAND | 转录调控网络预测数据库
- JFreeChart API中文文档
- 临床相关突变查询数据库
- TIGER | 人类胰岛基因变化查询数据库
- 视频边缘计算网关EasyNVR在视频整体监控解决方案中的应用分析
- Apache Arrow - 大数据在数据湖后的下一个风向标
- 常见的电商数据指标体系
- AKShare-艺人数据-艺人流量价值
- MySQL中多表联合查询与子查询的这些区别,你可能不知道!