一般视频通道接入EasyNVR后,视频广场就会清楚显示视频的快照和在线情况,快照默认一分钟更新一次,在线情况也是同步更新。
有EasyNVR的用户反馈在平台中,通道显示是离线状态,但是流可以正常播放。经过多次观察后发现用户的流实际是不稳定的,经常性在线离线反复跳跃。
这里我们需要提到一个底层库EasyStreamClient,这个库有个现象,就是流只会连接一次,如果流离线了,连接失败就会阻塞,所以如果流再次上线也是不会重新连接的,造成流实际在线但是EasyNVR上显示离线。
底层库逻辑改为连接后无论在不在线都直接返回结果。如果不在线就继续重连,修复测试后离线不会上线的问题解决了,但是在给用户测试时出现cpu升高的情况,而我们本地多次测试都没有这种情况发生。
接着查看了EasyNVR的线程,打印了线程里的状态,发现实际连接的流端口和用户填写的不一致,如下:
抓包分析后发现用户的流会出现重定向的情况:
根据以上我们确定是重定向的流消耗了cpu资源,在我们内部经过多次测试和讨论后,猜测是ffmpeg针对这种重定向的流处理机制有问题,于是尝试升级了EasyStreamClient库里的ffmpeg版本,升级后经过多天测试发现cpu正常了,该问题也得到了解决。