[发明专利]一种基于Redis缓存超时的设备在线状态计算方法在审
申请号: | 202110172147.9 | 申请日: | 2021-02-08 |
公开(公告)号: | CN112969064A | 公开(公告)日: | 2021-06-15 |
发明(设计)人: | 张亚南;马明普;战新刚;王壮 | 申请(专利权)人: | 智洋创新科技股份有限公司 |
主分类号: | H04N17/00 | 分类号: | H04N17/00;H04L12/26 |
代理公司: | 济南竹森知识产权代理事务所(普通合伙) 37270 | 代理人: | 吕利敏 |
地址: | 255188 山东省淄*** | 国省代码: | 山东;37 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 redis 缓存 超时 设备 在线 状态 计算方法 | ||
一种基于Redis缓存超时的设备在线状态计算方法,包括如下步骤:记录设备心跳时间,设置超时时间;视频设备周期性向信令服务器发送心跳报文,更新Redis缓存中存放设备的在线时间,重置缓存中的KEY值对应的超时时间;当视频设备超时未发送心跳报文时,Redis缓存触发KEY值超时事件,信令服务器设置与KEY值对应的视频设备状态为离线;当离线后,如果视频设备再次开始周期性发送心跳报文时,重复第一步。采用本发明所述的基于Redis缓存超时的设备在线状态计算方法,具有简单方便,执行效率高,支持的视频设备并发连接数量大等特点,可以在第一时间判断出设备的在线离线状态,没有设备超时的情况,几乎不占用CPU。
技术领域
本发明涉及一种基于Redis缓存超时的设备在线状态计算方法,属于综合智能安防的技术领域。
背景技术
基于GB/T28181国标协议的视频设备为兼容各种视频设备的网络架构和网络状况:其采用的是注册报文加心跳报文的方式来维护设备在线、离线状态,其中,所述注册报文为设备首次在信令服务器鉴权验证,验证成功后,设备周期性发送心跳报文,维护与信令服务器的连接状态。针对设备在线、离线状态主要是记录设备的心跳时间,利用线程轮询进行当前时间与最新心跳时间的对比:当两者的时间差大于规定的超时间时,则判断设备为离线,但是该方式在大量设备连接时执行效率低,判断不及时。
发明内容
针对现有技术存在的上述缺陷,本发明提出了一种基于Redis缓存超时的设备在线状态计算方法。本发明是通过监听Redis缓存的超时事件,来判断设备的在线、离线状态。
本发明的技术方案如下:
一种基于Redis缓存超时的设备在线状态计算方法,其特征在于,包括如下步骤:
第一步:记录设备心跳时间,设置超时时间,包括S1-S2:
S1:视频设备向信令服务器发送注册报文;
S2:信令服务器向Redis缓存中存放设备在线时间,KEY为视频设备的唯一标识,如视频设备编号,并设置KEY值对应的超时时间;
第二步:视频设备周期性向信令服务器发送心跳报文,更新Redis缓存中存放设备的在线时间,重置缓存中的KEY值对应的超时时间;
第三步:当视频设备超时未发送心跳报文时,Redis缓存触发KEY值超时事件,信令服务器设置与KEY值对应的视频设备状态为离线;
当离线后,如果视频设备再次开始周期性发送心跳报文时,重复第一步。
根据本发明优选的,在步骤S1中,所述视频设备是根据GB/T28181国标协议(《安全防范视频监控联网系统信息传输、交换、控制技术要求》)向信令服务器发送注册报文。
根据本发明优选的,所述视频设备是基于GB/T28181国标协议的视频设备。
根据本发明优选的,所述第一步中的信令服务器为处理GB/T28181国际协议中设备报文交互的服务器。
根据本发明优选的,所述第一步中的超时时间为:Redis移除缓存数据的时间。
本发明有益技术效果:
采用本发明所述的基于Redis缓存超时的设备在线状态计算方法,该方法简单方便,执行效率高,支持的视频设备并发连接数量大等特点。在大量设备中的部分设备上线离线时,传统队列轮询的方式,判断速度取决于轮询速度,轮询速度快则非常占用CPU,轮询速度慢则判断不及时。采用本发明的方式,则可以在第一时间判断出设备的在线离线状态,没有设备超时的情况,几乎不占用CPU。
附图说明
图1是本发明所述一种基于Redis缓存超时的设备在线状态计算方法的流程框图。
具体实施方式
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于智洋创新科技股份有限公司,未经智洋创新科技股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110172147.9/2.html,转载请声明来源钻瓜专利网。