diff --git a/src/backend/job-manage/service-job-manage/src/main/java/com/tencent/bk/job/manage/service/impl/HostServiceImpl.java b/src/backend/job-manage/service-job-manage/src/main/java/com/tencent/bk/job/manage/service/impl/HostServiceImpl.java index 9406b48f8f..bcefafc269 100644 --- a/src/backend/job-manage/service-job-manage/src/main/java/com/tencent/bk/job/manage/service/impl/HostServiceImpl.java +++ b/src/backend/job-manage/service-job-manage/src/main/java/com/tencent/bk/job/manage/service/impl/HostServiceImpl.java @@ -741,7 +741,7 @@ public List findStatusChangedHosts(List hostList) queryAgentStatusClient.batchGetAgentStatus(cloudIpList); for (HostSimpleDTO host : hostList) { QueryAgentStatusClient.AgentStatus agentStatus = agentStatusMap.get(host.getCloudIp()); - if(host.getGseAgentAlive() != agentStatus.status){ + if (host.getGseAgentAlive() != agentStatus.status) { host.setGseAgentAlive(agentStatus.status); statusChangedHosts.add(host); } @@ -1436,7 +1436,8 @@ public int updateHostsStatus(List simpleHostList) { .collect(Collectors.groupingBy(HostSimpleDTO::getGseAgentAlive, Collectors.mapping(HostSimpleDTO::getHostId, Collectors.toList()))); for (Integer status : statusGroupMap.keySet()) { - updateCount += applicationHostDAO.batchUpdateHostStatusByHostIds(status, statusGroupMap.get(status)); + updateCount += applicationHostDAO.batchUpdateHostStatusByHostIds(status, + statusGroupMap.get(status)); } start += batchSize; } while (end < size); @@ -1522,6 +1523,11 @@ public ServiceListAppHostResultDTO listAppHosts(Long appId, } }); + // 对于判定为其他业务下的主机,可能是缓存数据不准确导致,需要根据CMDB实时数据进行二次判定 + if (CollectionUtils.isNotEmpty(notInAppHosts)) { + reConfirmNotInAppHostsByCmdb(notInAppHosts, notExistHosts, validHosts, appId, includeBizIds); + } + if (CollectionUtils.isNotEmpty(notExistHosts) || CollectionUtils.isNotEmpty(notInAppHosts)) { log.info("Contains invalid hosts, appId: {}, notExistHosts: {}, hostsInOtherApp: {}", appId, notExistHosts, notInAppHosts); @@ -1534,9 +1540,75 @@ public ServiceListAppHostResultDTO listAppHosts(Long appId, return result; } - private Pair, List> listHostsFromCacheOrCmdb(Collection hosts) { - List appHosts = new ArrayList<>(); + /** + * 对于判定为其他业务下的主机,可能是缓存数据不准确导致,根据CMDB实时数据进行二次判定 + * + * @param notInAppHosts 前期判定为在其他业务下的主机,在该方法中数据可能被修改 + * @param notExistHosts 前期判定为不存在的主机,在该方法中数据可能被修改 + * @param validHosts 前期判定为在业务下的主机,在该方法中数据可能被修改 + * @param appId Job内业务ID + * @param includeBizIds Job内业务ID可能对应的多个CMDB业务ID列表 + */ + private void reConfirmNotInAppHostsByCmdb(List notInAppHosts, + List notExistHosts, + List validHosts, + Long appId, + List includeBizIds) { + Pair, List> cmdbHostsPair = listHostsFromCmdb(notInAppHosts); + if (CollectionUtils.isNotEmpty(cmdbHostsPair.getLeft())) { + notExistHosts.addAll(cmdbHostsPair.getLeft()); + } + List cmdbExistHosts = cmdbHostsPair.getRight(); + if (CollectionUtils.isNotEmpty(cmdbExistHosts)) { + notInAppHosts.clear(); + List cmdbValidHosts = new ArrayList<>(); + cmdbExistHosts.forEach(existHost -> { + if (includeBizIds.contains(existHost.getBizId())) { + validHosts.add(existHost.toHostDTO()); + cmdbValidHosts.add(existHost); + } else { + notInAppHosts.add(existHost.toHostDTO()); + } + }); + if (!cmdbValidHosts.isEmpty()) { + log.info( + "{} hosts belong to appId {} after check in cmdb, cmdbValidHosts={}", + cmdbValidHosts.size(), + appId, + cmdbValidHosts + ); + } + } + } + + private Pair, List> listHostsFromCmdb(Collection hosts) { List notExistHosts = new ArrayList<>(); + List appHosts = new ArrayList<>(); + Pair, List> pair = separateByHostIdOrCloudIp(hosts); + List hostIds = pair.getLeft(); + List cloudIps = pair.getRight(); + if (CollectionUtils.isNotEmpty(hostIds)) { + Pair, List> result = new ListHostByHostIdsStrategy().listHostsFromCmdb(hostIds); + appHosts.addAll(result.getRight()); + if (CollectionUtils.isNotEmpty(result.getLeft())) { + result.getLeft().forEach(notExistHostId -> { + notExistHosts.add(HostDTO.fromHostId(notExistHostId)); + }); + } + } + if (CollectionUtils.isNotEmpty(cloudIps)) { + Pair, List> result = new ListHostByIpsStrategy().listHostsFromCmdb(cloudIps); + appHosts.addAll(result.getRight()); + if (CollectionUtils.isNotEmpty(result.getLeft())) { + result.getLeft().forEach(notExistCloudIp -> { + notExistHosts.add(HostDTO.fromCloudIp(notExistCloudIp)); + }); + } + } + return Pair.of(notExistHosts, appHosts); + } + + private Pair, List> separateByHostIdOrCloudIp(Collection hosts) { List hostIds = new ArrayList<>(); List cloudIps = new ArrayList<>(); hosts.forEach(host -> { @@ -1546,6 +1618,15 @@ private Pair, List> listHostsFromCacheOrCmdb(Collect cloudIps.add(host.toCloudIp()); } }); + return Pair.of(hostIds, cloudIps); + } + + private Pair, List> listHostsFromCacheOrCmdb(Collection hosts) { + List appHosts = new ArrayList<>(); + List notExistHosts = new ArrayList<>(); + Pair, List> pair = separateByHostIdOrCloudIp(hosts); + List hostIds = pair.getLeft(); + List cloudIps = pair.getRight(); if (CollectionUtils.isNotEmpty(hostIds)) { Pair, List> result = listHostsByStrategy(hostIds, new ListHostByHostIdsStrategy()); appHosts.addAll(result.getRight());