in oap-server/server-core/src/main/java/org/apache/skywalking/oap/server/core/query/ServiceInstanceTopologyBuilder.java [58:140]
ServiceInstanceTopology build(List<Call.CallDetail> serviceInstanceRelationClientCalls,
List<Call.CallDetail> serviceInstanceRelationServerCalls) {
Map<String, ServiceInstanceNode> nodes = new HashMap<>();
List<Call> calls = new LinkedList<>();
HashMap<String, Call> callMap = new HashMap<>();
/*
* Build Calls and Nodes based on client side detected data.
*/
for (Call.CallDetail clientCall : serviceInstanceRelationClientCalls) {
final IDManager.ServiceInstanceID.InstanceIDDefinition sourceServiceInstance = IDManager.ServiceInstanceID.analysisId(
clientCall.getSource());
final IDManager.ServiceID.ServiceIDDefinition sourceService = IDManager.ServiceID.analysisId(
sourceServiceInstance.getServiceId());
IDManager.ServiceInstanceID.InstanceIDDefinition destServiceInstance = IDManager.ServiceInstanceID.analysisId(
clientCall.getTarget());
final IDManager.ServiceID.ServiceIDDefinition destService = IDManager.ServiceID.analysisId(
destServiceInstance.getServiceId());
if (!nodes.containsKey(clientCall.getSource())) {
nodes.put(clientCall.getSource(), buildNode(sourceService, sourceServiceInstance));
}
if (!nodes.containsKey(clientCall.getTarget())) {
final ServiceInstanceNode node = buildNode(destService, destServiceInstance);
nodes.put(clientCall.getTarget(), node);
}
if (!callMap.containsKey(clientCall.getId())) {
Call call = new Call();
callMap.put(clientCall.getId(), call);
call.setSource(clientCall.getSource());
call.setTarget(clientCall.getTarget());
call.setId(clientCall.getId());
call.addDetectPoint(DetectPoint.CLIENT);
calls.add(call);
}
}
/*
* Build Calls and Nodes based on server side detected data.
*/
for (Call.CallDetail serverCall : serviceInstanceRelationServerCalls) {
final IDManager.ServiceInstanceID.InstanceIDDefinition sourceServiceInstance = IDManager.ServiceInstanceID.analysisId(
serverCall.getSource());
final IDManager.ServiceID.ServiceIDDefinition sourceService = IDManager.ServiceID.analysisId(
sourceServiceInstance.getServiceId());
IDManager.ServiceInstanceID.InstanceIDDefinition destServiceInstance = IDManager.ServiceInstanceID.analysisId(
serverCall.getTarget());
final IDManager.ServiceID.ServiceIDDefinition destService = IDManager.ServiceID.analysisId(
destServiceInstance.getServiceId());
if (!nodes.containsKey(serverCall.getSource())) {
nodes.put(serverCall.getSource(), buildNode(sourceService, sourceServiceInstance));
}
if (!nodes.containsKey(serverCall.getTarget())) {
final ServiceInstanceNode node = buildNode(destService, destServiceInstance);
nodes.put(serverCall.getTarget(), node);
}
if (!callMap.containsKey(serverCall.getId())) {
Call call = new Call();
callMap.put(serverCall.getId(), call);
call.setSource(serverCall.getSource());
call.setTarget(serverCall.getTarget());
call.setId(serverCall.getId());
call.addDetectPoint(DetectPoint.SERVER);
calls.add(call);
} else {
Call call = callMap.get(serverCall.getId());
call.addDetectPoint(DetectPoint.SERVER);
}
}
ServiceInstanceTopology topology = new ServiceInstanceTopology();
topology.getCalls().addAll(calls);
topology.getNodes().addAll(nodes.values());
return topology;
}