syntax = "proto3"; option java_multiple_files = true; option java_package = "org.skywalking.apm.network.proto"; import "Downstream.proto"; //discovery service for application instance, this service is called when application starts //or http client connection switch to another collector server instance service InstanceDiscoveryService { rpc register (ApplicationInstance) returns (ApplicationInstanceMapping) { } rpc heartbeat (ApplicationInstanceHeartbeat) returns (Downstream) { } rpc registerRecover (ApplicationInstanceRecover) returns (Downstream) { } } message ApplicationInstance { int32 applicationId = 1; string agentUUID = 2; int64 registerTime = 3; OSInfo osinfo = 4; } message ApplicationInstanceMapping { int32 applicationId = 1; int32 applicationInstanceId = 2; } message ApplicationInstanceRecover { int32 applicationId = 1; int32 applicationInstanceId = 2; int64 registerTime = 3; OSInfo osinfo = 4; } message ApplicationInstanceHeartbeat { int32 applicationInstanceId = 1; int64 heartbeatTime = 2; } message OSInfo { string osName = 1; string hostname = 2; int32 processNo = 3; repeated string ipv4s = 4; } //discovery service for ServiceName by Network address or application code service ServiceNameDiscoveryService { rpc discovery (ServiceNameCollection) returns (ServiceNameMappingCollection) { } } message ServiceNameCollection { repeated ServiceNameElement elements = 1; } message ServiceNameMappingCollection { repeated ServiceNameMappingElement elements = 1; } message ServiceNameMappingElement { int32 serviceId = 1; ServiceNameElement element = 2; } message ServiceNameElement { string serviceName = 1; int32 applicationId = 2; }