mirror of
https://github.com/status-im/consul.git
synced 2025-01-22 11:40:06 +00:00
92aab7ea31
[OG Author: michael.zalimeni@hashicorp.com, rebase needed a separate PR] * v2: support virtual port in Service port references In addition to Service target port references, allow users to specify a port by stringified virtual port value. This is useful in environments such as Kubernetes where typical configuration is written in terms of Service virtual ports rather than workload (pod) target port names. Retaining the option of referencing target ports by name supports VMs, Nomad, and other use cases where virtual ports are not used by default. To support both uses cases at once, we will strictly interpret port references based on whether the value is numeric. See updated `ServicePort` docs for more details. * v2: update service ref docs for virtual port support Update proto and generated .go files with docs reflecting virtual port reference support. * v2: add virtual port references to L7 topo test Add coverage for mixed virtual and target port references to existing test. * update failover policy controller tests to work with computed failover policy and assert error conditions against FailoverPolicy and ComputedFailoverPolicy resources * accumulate services; don't overwrite them in enterprise --------- Co-authored-by: Michael Zalimeni <michael.zalimeni@hashicorp.com> Co-authored-by: R.B. Boyer <rb@hashicorp.com>
47 lines
1.7 KiB
Protocol Buffer
47 lines
1.7 KiB
Protocol Buffer
// Copyright (c) HashiCorp, Inc.
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
syntax = "proto3";
|
|
|
|
package hashicorp.consul.catalog.v2beta1;
|
|
|
|
import "pbcatalog/v2beta1/protocol.proto";
|
|
import "pbcatalog/v2beta1/selector.proto";
|
|
import "pbresource/annotations.proto";
|
|
|
|
message Service {
|
|
option (hashicorp.consul.resource.spec) = {scope: SCOPE_NAMESPACE};
|
|
|
|
// workloads is a selector for the workloads this service should represent.
|
|
WorkloadSelector workloads = 1;
|
|
// ports is the list of mappings of workload ports that this service
|
|
// represents.
|
|
repeated ServicePort ports = 2;
|
|
|
|
// virtual_ips is a list of virtual IPs for this service. This is useful when you need to set
|
|
// an IP from an external system (like Kubernetes). This can be an IPv4 or IPv6 string.
|
|
repeated string virtual_ips = 3;
|
|
}
|
|
|
|
// ServicePort declares a port exposed by the service that can be used in config and xRoute
|
|
// references.
|
|
//
|
|
// For outside references to a service port by string identifier (e.g. in xRoutes and xPolicies),
|
|
// there are two forms supported:
|
|
// - A numeric value exclusively indicates a ServicePort.VirtualPort
|
|
// - A non-numeric value exclusively indicates a ServicePort.TargetPort
|
|
message ServicePort {
|
|
// virtual_port is the port that could only be used when transparent
|
|
// proxy is used alongside a virtual IP or a virtual DNS address.
|
|
// This value is ignored in other cases. Whether or not using transparent
|
|
// proxy, this value is optional.
|
|
uint32 virtual_port = 1;
|
|
|
|
// target_port is the name of the workload port.
|
|
string target_port = 2;
|
|
|
|
// protocol is the port's protocol. This should be set to "mesh"
|
|
// if the target port is the proxy's inbound port.
|
|
Protocol protocol = 3;
|
|
}
|