| | |
| | | |
| | | import com.genersoft.iot.vmp.gb28181.bean.ParentPlatform; |
| | | import com.genersoft.iot.vmp.gb28181.bean.ParentPlatformCatch; |
| | | import com.genersoft.iot.vmp.gb28181.bean.PlatformRegister; |
| | | import com.genersoft.iot.vmp.gb28181.event.EventPublisher; |
| | | import com.genersoft.iot.vmp.gb28181.event.SipSubscribe; |
| | | import com.genersoft.iot.vmp.gb28181.transmit.cmd.ISIPCommanderForPlatform; |
| | | import com.genersoft.iot.vmp.storager.IRedisCatchStorage; |
| | | import com.genersoft.iot.vmp.storager.IVideoManagerStorager; |
| | | import com.genersoft.iot.vmp.storager.IVideoManagerStorage; |
| | | import org.jetbrains.annotations.NotNull; |
| | | import org.slf4j.Logger; |
| | | import org.slf4j.LoggerFactory; |
| | |
| | | import org.springframework.context.ApplicationListener; |
| | | import org.springframework.stereotype.Component; |
| | | |
| | | import javax.sip.ResponseEvent; |
| | | import javax.sip.message.Response; |
| | | |
| | | /** |
| | | * @Description: 平台心跳超时事件 |
| | | * @description: 平台心跳超时事件 |
| | | * @author: panll |
| | | * @date: 2020年11月5日 10:00 |
| | | */ |
| | |
| | | private final static Logger logger = LoggerFactory.getLogger(PlatformKeepaliveExpireEventLister.class); |
| | | |
| | | @Autowired |
| | | private IVideoManagerStorager storager; |
| | | private IVideoManagerStorage storager; |
| | | |
| | | @Autowired |
| | | private IRedisCatchStorage redisCatchStorage; |
| | |
| | | if (logger.isDebugEnabled()) { |
| | | logger.debug("平台心跳到期事件事件触发,平台国标ID:" + event.getPlatformGbID()); |
| | | } |
| | | ParentPlatform parentPlatform = storager.queryParentPlatById(event.getPlatformGbID()); |
| | | ParentPlatform parentPlatform = storager.queryParentPlatByServerGBId(event.getPlatformGbID()); |
| | | ParentPlatformCatch parentPlatformCatch = redisCatchStorage.queryPlatformCatchInfo(event.getPlatformGbID()); |
| | | parentPlatformCatch.setParentPlatform(parentPlatform); |
| | | if (parentPlatformCatch == null) { |
| | | return; |
| | | } |
| | | if (parentPlatform == null) { |
| | | logger.debug("平台心跳到期事件事件触发,但平台已经删除!!! 平台国标ID:" + event.getPlatformGbID()); |
| | | return; |
| | | } |
| | | if (parentPlatformCatch == null) { |
| | | return; |
| | | } |
| | | parentPlatformCatch.setParentPlatform(parentPlatform); |
| | | // 发送心跳 |
| | | if (parentPlatformCatch.getKeepAliveReply() >= 3) { |
| | | // 有3次未收到心跳回复, 设置平台状态为离线, 开始重新注册 |
| | | logger.warn("有3次未收到心跳回复,标记设置平台状态为离线, 并重新注册 平台国标ID:" + event.getPlatformGbID()); |
| | | storager.updateParentPlatformStatus(event.getPlatformGbID(), false); |
| | | publisher.platformNotRegisterEventPublish(event.getPlatformGbID()); |
| | | parentPlatformCatch.setKeepAliveReply(0); |
| | | redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch); |
| | | }else { |
| | | // 再次发送心跳 |
| | | String callId = sipCommanderForPlatform.keepalive(parentPlatform); |
| | |
| | | redisCatchStorage.updatePlatformKeepalive(parentPlatform); |
| | | redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch); |
| | | |
| | | sipSubscribe.addOkSubscribe(callId, (ResponseEvent responseEvent) ->{ |
| | | if (responseEvent.getResponse().getStatusCode() == Response.OK) { |
| | | sipSubscribe.addOkSubscribe(callId, (SipSubscribe.EventResult eventResult) ->{ |
| | | if (eventResult.statusCode == Response.OK) { |
| | | // 收到心跳响应信息, |
| | | parentPlatformCatch.setKeepAliveReply(0); |
| | | redisCatchStorage.updatePlatformCatchInfo(parentPlatformCatch); |