不管是网页直播还是手机直播,都不可避免会有卡顿的问题,作为视频平台的开发者,我们知道视频卡顿的原因有很多,包括时间戳问题以及网络环境问题。此外还有一种情况,就是在我们已经开发的视频平台EasyCVR中,接入过多通道设备,也会出现卡顿问题。
![](https://img.laitimes.com/img/9ZDMuAjOiMmIsIjOiQnIsISPrdEZwZ1Rh5WNXp1bwNjW1ZUba9VZwlHdsATOfd3bkFGazxCMx8VesATMfhHLlN3XnxCMwEzX0xiRGZkRGZ0Xy9GbvNGLpZTY1EmMZVDUSFTU4VFRR9Fd4VGdsYTMfVmepNHLrJXYtJXZ0F2dvwVZnFWbp1zczV2YvJHctM3cv1Ce-cmbw5yYhRTOykzMxYWZjVmZxAzMkhTYzQjZ2QjZmNWMxczMi9CX1IzLcRDMxIDMy8CXn9Gbi9CXzV2Zh1WavwVbvNmLvR3YxUjLyM3Lc9CX6MHc0RHaiojIsJye.png)
我们将代码重构,当前端查询设备时候,添加分页字段,start 和limit
秉着展示多少查询多少的原则进行修改,添加如下代码:
if params["start"] != "" && params["limit"] != "" {
start, _ = strconv.Atoi(params["start"])
limit, _ = strconv.Atoi(params["limit"])
}
ack := NewMsgAck()
ack.EasyDarwin.Header.MessageType = MSG_SC_SERVER_GET_CHANNELS_ACK
rows := make([]map[string]interface{}, 0)
db.SQLite.LogMode(true)
channelscount := cvrservice.GetDeviceService().GetChannels(params["device"], params["channel"], params["q"], 0, 0)
channels := cvrservice.GetDeviceService().GetChannels(params["device"], params["channel"], params["q"], uint(start), uint(limit))
tempdbDBChannel := make([]cvrdo.DBChannelInfo, 0)
再去请求查询通,此时生成的sql已经是携带分页参数过后的了。