old mode 100644
new mode 100755
| | |
| | | import com.alibaba.fastjson2.JSON; |
| | | import com.genersoft.iot.vmp.common.VideoManagerConstants; |
| | | import com.genersoft.iot.vmp.conf.DynamicTask; |
| | | import com.genersoft.iot.vmp.conf.UserSetting; |
| | | import com.genersoft.iot.vmp.service.IStreamPushService; |
| | | import com.genersoft.iot.vmp.service.bean.PushStreamStatusChangeFromRedisDto; |
| | | import com.genersoft.iot.vmp.storager.IRedisCatchStorage; |
| | |
| | | |
| | | private final static Logger logger = LoggerFactory.getLogger(RedisPushStreamStatusMsgListener.class); |
| | | |
| | | private boolean taskQueueHandlerRun = false; |
| | | |
| | | @Autowired |
| | | private IRedisCatchStorage redisCatchStorage; |
| | | |
| | |
| | | |
| | | @Autowired |
| | | private DynamicTask dynamicTask; |
| | | |
| | | @Autowired |
| | | private UserSetting userSetting; |
| | | |
| | | |
| | | |
| | |
| | | |
| | | @Override |
| | | public void onMessage(Message message, byte[] bytes) { |
| | | boolean isEmpty = taskQueue.isEmpty(); |
| | | logger.warn("[REDIS消息-推流设备状态变化]: {}", new String(message.getBody())); |
| | | taskQueue.offer(message); |
| | | |
| | | if (!taskQueueHandlerRun) { |
| | | taskQueueHandlerRun = true; |
| | | if (isEmpty) { |
| | | taskExecutor.execute(() -> { |
| | | while (!taskQueue.isEmpty()) { |
| | | Message msg = taskQueue.poll(); |
| | | PushStreamStatusChangeFromRedisDto statusChangeFromPushStream = JSON.parseObject(msg.getBody(), PushStreamStatusChangeFromRedisDto.class); |
| | | if (statusChangeFromPushStream == null) { |
| | | logger.warn("[REDIS消息]推流设备状态变化消息解析失败"); |
| | | continue; |
| | | } |
| | | // 取消定时任务 |
| | | dynamicTask.stop(VideoManagerConstants.VM_MSG_GET_ALL_ONLINE_REQUESTED); |
| | | if (statusChangeFromPushStream.isSetAllOffline()) { |
| | | // 所有设备离线 |
| | | streamPushService.allStreamOffline(); |
| | | } |
| | | if (statusChangeFromPushStream.getOfflineStreams() != null |
| | | && statusChangeFromPushStream.getOfflineStreams().size() > 0) { |
| | | // 更新部分设备离线 |
| | | streamPushService.offline(statusChangeFromPushStream.getOfflineStreams()); |
| | | } |
| | | if (statusChangeFromPushStream.getOnlineStreams() != null && |
| | | statusChangeFromPushStream.getOnlineStreams().size() > 0) { |
| | | // 更新部分设备上线 |
| | | streamPushService.online(statusChangeFromPushStream.getOnlineStreams()); |
| | | try { |
| | | PushStreamStatusChangeFromRedisDto statusChangeFromPushStream = JSON.parseObject(msg.getBody(), PushStreamStatusChangeFromRedisDto.class); |
| | | if (statusChangeFromPushStream == null) { |
| | | logger.warn("[REDIS消息]推流设备状态变化消息解析失败"); |
| | | continue; |
| | | } |
| | | // 取消定时任务 |
| | | dynamicTask.stop(VideoManagerConstants.VM_MSG_GET_ALL_ONLINE_REQUESTED); |
| | | if (statusChangeFromPushStream.isSetAllOffline()) { |
| | | // 所有设备离线 |
| | | streamPushService.allStreamOffline(); |
| | | } |
| | | if (statusChangeFromPushStream.getOfflineStreams() != null |
| | | && statusChangeFromPushStream.getOfflineStreams().size() > 0) { |
| | | // 更新部分设备离线 |
| | | streamPushService.offline(statusChangeFromPushStream.getOfflineStreams()); |
| | | } |
| | | if (statusChangeFromPushStream.getOnlineStreams() != null && |
| | | statusChangeFromPushStream.getOnlineStreams().size() > 0) { |
| | | // 更新部分设备上线 |
| | | streamPushService.online(statusChangeFromPushStream.getOnlineStreams()); |
| | | } |
| | | }catch (Exception e) { |
| | | logger.warn("[REDIS消息-推流设备状态变化] 发现未处理的异常, \r\n{}", JSON.toJSONString(message)); |
| | | logger.error("[REDIS消息-推流设备状态变化] 异常内容: ", e); |
| | | } |
| | | } |
| | | taskQueueHandlerRun = false; |
| | | }); |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public void run(ApplicationArguments args) throws Exception { |
| | | // 启动时设置所有推流通道离线,发起查询请求 |
| | | redisCatchStorage.sendStreamPushRequestedMsgForStatus(); |
| | | dynamicTask.startDelay(VideoManagerConstants.VM_MSG_GET_ALL_ONLINE_REQUESTED, ()->{ |
| | | logger.info("[REDIS消息]未收到redis回复推流设备状态,执行推流设备离线"); |
| | | // 五秒收不到请求就设置通道离线,然后通知上级离线 |
| | | streamPushService.allStreamOffline(); |
| | | }, 5000); |
| | | if (!userSetting.isUsePushingAsStatus()) { |
| | | // 启动时设置所有推流通道离线,发起查询请求 |
| | | redisCatchStorage.sendStreamPushRequestedMsgForStatus(); |
| | | dynamicTask.startDelay(VideoManagerConstants.VM_MSG_GET_ALL_ONLINE_REQUESTED, ()->{ |
| | | logger.info("[REDIS消息]未收到redis回复推流设备状态,执行推流设备离线"); |
| | | // 五秒收不到请求就设置通道离线,然后通知上级离线 |
| | | streamPushService.allStreamOffline(); |
| | | }, 5000); |
| | | } |
| | | } |
| | | |
| | | } |