diff --git a/.changelog/4301.txt b/.changelog/4301.txt new file mode 100644 index 0000000000..5d952e4a1e --- /dev/null +++ b/.changelog/4301.txt @@ -0,0 +1,3 @@ +```release-note:feature +control-plane: Add available Zone Kubernetes Topology Metadata for NodePort Service when Syncing Kubernetes Services. +``` \ No newline at end of file diff --git a/control-plane/catalog/to-consul/resource.go b/control-plane/catalog/to-consul/resource.go index 9e48305a30..dd42b6d2f5 100644 --- a/control-plane/catalog/to-consul/resource.go +++ b/control-plane/catalog/to-consul/resource.go @@ -662,7 +662,7 @@ func (t *ServiceResource) generateRegistrations(key string) { r.Service = &rs r.Service.ID = serviceID(r.Service.Service, endpointAddr) r.Service.Address = address.Address - + r.Service.Meta = updateServiceMeta(baseService.Meta, endpoint) t.consulMap[key] = append(t.consulMap[key], &r) // Only consider the first address that matches. In some cases // there will be multiple addresses like when using AWS CNI. @@ -683,7 +683,7 @@ func (t *ServiceResource) generateRegistrations(key string) { r.Service = &rs r.Service.ID = serviceID(r.Service.Service, endpointAddr) r.Service.Address = address.Address - + r.Service.Meta = updateServiceMeta(baseService.Meta, endpoint) t.consulMap[key] = append(t.consulMap[key], &r) // Only consider the first address that matches. In some cases // there will be multiple addresses like when using AWS CNI. @@ -778,23 +778,7 @@ func (t *ServiceResource) registerServiceInstance( r.Service.ID = serviceID(r.Service.Service, addr) r.Service.Address = addr r.Service.Port = epPort - r.Service.Meta = make(map[string]string) - // Deepcopy baseService.Meta into r.Service.Meta as baseService is shared - // between all nodes of a service - for k, v := range baseService.Meta { - r.Service.Meta[k] = v - } - if endpoint.TargetRef != nil { - r.Service.Meta[ConsulK8SRefValue] = endpoint.TargetRef.Name - r.Service.Meta[ConsulK8SRefKind] = endpoint.TargetRef.Kind - } - if endpoint.NodeName != nil { - r.Service.Meta[ConsulK8SNodeName] = *endpoint.NodeName - } - if endpoint.Zone != nil { - r.Service.Meta[ConsulK8STopologyZone] = *endpoint.Zone - } - + r.Service.Meta = updateServiceMeta(baseService.Meta, endpoint) r.Check = &consulapi.AgentCheck{ CheckID: consulHealthCheckID(endpointSlice.Namespace, serviceID(r.Service.Service, addr)), Name: consulKubernetesCheckName, @@ -1110,3 +1094,25 @@ func getServiceWeight(weight string) (int, error) { return weightI, nil } + +// deepcopy baseService.Meta into r.Service.Meta as baseService is shared between all nodes of a service. +// update service meta with k8s topology info. +func updateServiceMeta(baseServiceMeta map[string]string, endpoint discoveryv1.Endpoint) map[string]string { + + serviceMeta := make(map[string]string) + + for k, v := range baseServiceMeta { + serviceMeta[k] = v + } + if endpoint.TargetRef != nil { + serviceMeta[ConsulK8SRefValue] = endpoint.TargetRef.Name + serviceMeta[ConsulK8SRefKind] = endpoint.TargetRef.Kind + } + if endpoint.NodeName != nil { + serviceMeta[ConsulK8SNodeName] = *endpoint.NodeName + } + if endpoint.Zone != nil { + serviceMeta[ConsulK8STopologyZone] = *endpoint.Zone + } + return serviceMeta +} diff --git a/control-plane/catalog/to-consul/resource_test.go b/control-plane/catalog/to-consul/resource_test.go index 4951d1b107..ca45b9a4ed 100644 --- a/control-plane/catalog/to-consul/resource_test.go +++ b/control-plane/catalog/to-consul/resource_test.go @@ -859,6 +859,8 @@ func TestServiceResource_nodePort(t *testing.T) { require.Equal(r, "3.4.5.6", actual[2].Service.Address) require.Equal(r, 30000, actual[2].Service.Port) require.Equal(r, "k8s-sync", actual[2].Node) + require.Equal(r, "us-west-2a", actual[0].Service.Meta[ConsulK8STopologyZone]) + require.Equal(r, "us-west-2b", actual[1].Service.Meta[ConsulK8STopologyZone]) require.NotEqual(r, actual[0].Service.ID, actual[1].Service.ID) require.NotEqual(r, actual[0].Service.ID, actual[2].Service.ID) require.NotEqual(r, actual[1].Service.ID, actual[2].Service.ID)