package com.genersoft.iot.vmp.gb28181.event.online; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationListener; import org.springframework.stereotype.Component; import com.genersoft.iot.vmp.common.VideoManagerConstants; import com.genersoft.iot.vmp.storager.IVideoManagerStorager; import com.genersoft.iot.vmp.utils.redis.RedisUtil; /** * @Description: 在线事件监听器,监听到离线后,修改设备离在线状态。 设备在线有两个来源: * 1、设备主动注销,发送注销指令,{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.RegisterRequestProcessor} * 2、设备未知原因离线,心跳超时,{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.MessageRequestProcessor} * @author: swwheihei * @date: 2020年5月6日 下午1:51:23 */ @Component public class OnlineEventListener implements ApplicationListener { private final static Logger logger = LoggerFactory.getLogger(OnlineEventListener.class); @Autowired private IVideoManagerStorager storager; @Autowired private RedisUtil redis; @Override public void onApplicationEvent(OnlineEvent event) { if (logger.isDebugEnabled()) { logger.debug("设备离线事件触发,deviceId:" + event.getDeviceId() + ",from:" + event.getFrom()); } String key = VideoManagerConstants.KEEPLIVEKEY_PREFIX + event.getDeviceId(); boolean needUpdateStorager = false; switch (event.getFrom()) { // 注册时触发的在线事件,先在redis中增加超时超时监听 case VideoManagerConstants.EVENT_ONLINE_REGISTER: // TODO 超时时间暂时写死为180秒 redis.set(key, event.getDeviceId(), 180); needUpdateStorager = true; break; // 设备主动发送心跳触发的离线事件 case VideoManagerConstants.EVENT_ONLINE_KEEPLIVE: boolean exist = redis.hasKey(key); // 先判断是否还存在,当设备先心跳超时后又发送心跳时,redis没有监听,需要增加 if (!exist) { needUpdateStorager = true; redis.set(key, event.getDeviceId(), 180); } else { redis.expire(key, 180); } break; } if (needUpdateStorager) { // 处理离线监听 storager.online(event.getDeviceId()); } } }