[NET-7713] docs: Update v2 K8s docs to use virtual port references (#20695)

docs: Update v2 K8s docs to use virtual port references

Now that service virtual port references are supported in xRoutes and
config,

- Call out both formats accepted for service port references
- Update K8s examples to use virtual ports (most likely use case)
This commit is contained in:
Michael Zalimeni 2024-02-26 12:15:31 -05:00 committed by GitHub
parent 16a0800777
commit 50b442f7f2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 72 additions and 111 deletions

View File

@ -93,7 +93,7 @@ metadata:
namespace: <namespace> namespace: <namespace>
spec: spec:
parentRefs: parentRefs:
port: <portNameRoutedFrom> port: <portRoutedFrom>
- ref: - ref:
name: <nameRoutedFrom> name: <nameRoutedFrom>
type: type:
@ -104,7 +104,7 @@ spec:
- backendRefs: - backendRefs:
- backendRef: - backendRef:
datacenter: <datacenterRoutedTo> datacenter: <datacenterRoutedTo>
port: "<portNameRoutedTo>" port: "<portRoutedTo>"
ref: ref:
name: <nameRoutedTo> name: <nameRoutedTo>
type: type:
@ -230,7 +230,9 @@ Specifies the services and other resources to attach the route to. You can only
### `spec.parentRefs.port` ### `spec.parentRefs.port`
Specifies the name of the port that the configuration applies to. Specifies the port for the Consul service that the configuration applies to. This parameter can be either a virtual port number, such as a Kubernetes service port, or a non-numeric target port value representing a named workload port.
If you are not targeting a virtual port, specify the workload port name directly.
#### Values #### Values
@ -312,7 +314,9 @@ Specifies the name of the Consul datacenter that registered the Service backend
### `spec.rules.backendRefs.backendRef.port` ### `spec.rules.backendRefs.backendRef.port`
Specifies the name of the port for the Consul service that the configuration routes traffic to. Specifies the port for the Consul service that the configuration routes traffic to. This parameter can be either a virtual port number, such as a Kubernetes service port, or a non-numeric target port value representing a named workload port.
If you are not targeting a virtual port, specify the workload port name directly.
#### Values #### Values
@ -701,8 +705,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
rules: rules:
- backendRefs: - backendRefs:
- backendRef: - backendRef:
@ -712,8 +716,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
weight: 50 weight: 50
- backendRef: - backendRef:
ref: ref:
@ -722,8 +726,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "admin-workload" target port.
port: "admin-workload" port: "90"
weight: 50 weight: 50
``` ```
@ -750,8 +754,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
rules: rules:
- matches: - matches:
- headers: - headers:
@ -775,8 +779,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
- matches: - matches:
- headers: - headers:
- type: "HEADER_MATCH_TYPE_EXACT" - type: "HEADER_MATCH_TYPE_EXACT"
@ -799,6 +803,6 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api-admin name: api-admin
# The configuration targets the workload port, not the service port. # The virtual port number for the "admin-workload" target port.
port: "admin-workload" port: "90"
``` ```

View File

@ -97,7 +97,7 @@ metadata:
namespace: <namespace> namespace: <namespace>
spec: spec:
parentRefs: parentRefs:
port: <portNameRoutedFrom> port: <portRoutedFrom>
- ref: - ref:
name: <nameRoutedFrom> name: <nameRoutedFrom>
type: type:
@ -108,7 +108,7 @@ spec:
- backendRefs: - backendRefs:
- backendRef: - backendRef:
datacenter: <datacenterRoutedTo> datacenter: <datacenterRoutedTo>
port: <portNameRoutedTo> port: <portRoutedTo>
ref: ref:
name: <nameRoutedTo> name: <nameRoutedTo>
type: type:
@ -238,7 +238,9 @@ Specifies the services and other resources to attach the route to. You can only
### `spec.parentRefs.port` ### `spec.parentRefs.port`
Specifies the name of the port that the configuration applies to. Specifies the port for the Consul service that the configuration applies to. This parameter can be either a virtual port number, such as a Kubernetes service port, or a non-numeric target port value representing a named workload port.
If you are not targeting a virtual port, specify the workload port name directly.
#### Values #### Values
@ -320,7 +322,9 @@ Specifies the name of the Consul datacenter that registered the Service backend
### `spec.rules.backendRefs.backendRef.port` ### `spec.rules.backendRefs.backendRef.port`
Specifies the name of the port for the Consul service that the configuration routes traffic to. Specifies the name of the port for the Consul service that the configuration routes traffic to. This parameter can be either a virtual port number, such as a Kubernetes service port, or a non-numeric target port value representing a named workload port.
If you are not targeting a virtual port, specify the workload port name directly.
#### Values #### Values
@ -754,8 +758,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api" port: "80"
rules: rules:
- backendRefs: - backendRefs:
- backendRef: - backendRef:
@ -765,8 +769,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api" port: "80"
weight: 50 weight: 50
- backendRef: - backendRef:
ref: ref:
@ -775,8 +779,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "admin-workload" target port.
port: "admin" port: "90"
weight: 50 weight: 50
``` ```
@ -803,8 +807,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
rules: rules:
- matches: - matches:
- headers: - headers:
@ -828,8 +832,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
- matches: - matches:
- headers: - headers:
- type: "HEADER_MATCH_TYPE_EXACT" - type: "HEADER_MATCH_TYPE_EXACT"
@ -852,8 +856,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api-admin name: api-admin
# The configuration targets the workload port, not the service port. # The virtual port number for the "admin-workload" target port.
port: "admin-workload" port: "90"
``` ```
### Route traffic by matching header and query parameter ### Route traffic by matching header and query parameter
@ -877,8 +881,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
rules: rules:
- matches: - matches:
- headers: - headers:
@ -897,8 +901,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api-workload" port: "80"
- matches: - matches:
- headers: - headers:
- type: "HEADER_MATCH_TYPE_EXACT" - type: "HEADER_MATCH_TYPE_EXACT"
@ -916,6 +920,6 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api-admin name: api-admin
# The configuration targets the workload port, not the service port. # The virtual port number for the "admin-workload" target port.
port: "admin-workload" port: "90"
``` ```

View File

@ -60,7 +60,7 @@ metadata:
namespace: <namespace> namespace: <namespace>
spec: spec:
parentRefs: parentRefs:
port: <portNameRoutedFrom> port: <portRoutedFrom>
- ref: - ref:
name: <nameRoutedFrom> name: <nameRoutedFrom>
type: type:
@ -71,7 +71,7 @@ spec:
- backendRefs: - backendRefs:
- backendRef: - backendRef:
datacenter: <datacenterRoutedTo> datacenter: <datacenterRoutedTo>
port: <portNameRoutedTo> port: <portRoutedTo>
ref: ref:
name: <nameRoutedTo> name: <nameRoutedTo>
type: type:
@ -147,7 +147,7 @@ When using this CRD, the `spec` field closely resembles the `TCPRoute` GAMMA res
### `spec.parentRefs` ### `spec.parentRefs`
Specifies the services and other resources to attach the route to. You can only define one `parentsRefs` configuration for each route. To attach the route to multiple resources, specify additional [`spec.parentRefs.ref`](#spec-parentrefs-ref) configurations in the `parentsRefs` block. You can only specify the name of one port for the route. Any resources that send traffic through the route use the same port. Specifies the services and other resources to attach the route to. You can only define one `parentsRefs` configuration for each route. To attach the route to multiple resources, specify additional [`spec.parentRefs.ref`](#spec-parentrefs-ref) configurations in the `parentsRefs` block. You can only specify one port for the route. Any resources that send traffic through the route use the same port.
#### Values #### Values
@ -157,7 +157,9 @@ Specifies the services and other resources to attach the route to. You can only
### `spec.parentRefs.port` ### `spec.parentRefs.port`
Specifies the name of the port that the configuration applies to. Specifies the port for the Consul service that the configuration applies to. This parameter can be either a virtual port number, such as a Kubernetes service port, or a non-numeric target port value representing a named workload port.
If you are not targeting a virtual port, specify the workload port name directly.
#### Values #### Values
@ -239,7 +241,9 @@ Specifies the name of the Consul datacenter that registered the Service backend
### `spec.rules.backendRefs.backendRef.port` ### `spec.rules.backendRefs.backendRef.port`
Specifies the name of the port for the Consul service that the configuration routes traffic to. Specifies the port for the Consul service that the configuration routes traffic to. This parameter can be either a virtual port number, such as a Kubernetes service port, or a non-numeric target port value representing a named workload port.
If you are not targeting a virtual port, specify the workload port name directly.
#### Values #### Values
@ -298,7 +302,7 @@ The following examples demonstrate common TCPRoute CRD configuration patterns fo
### Split TCP traffic between two ports ### Split TCP traffic between two ports
The following example splits traffic for the `api` service. TCP traffic for services registered to the Consul catalog that are available at the `api` port is split so that 50% of the traffic routes to the service at the `api` port and 50% routes to the service at the `admin` port. The following example splits traffic for the `api` service. TCP traffic for services registered to the Consul catalog that are available at the `api-workload` port is split so that 50% of the traffic routes to the service at the `api-workload` port and 50% routes to the service at the `admin-workload` port.
```yaml ```yaml
apiVersion: mesh.consul.hashicorp.com/v2beta1 apiVersion: mesh.consul.hashicorp.com/v2beta1
@ -314,8 +318,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api" port: "80"
rules: rules:
- backendRefs: - backendRefs:
- backendRef: - backendRef:
@ -325,8 +329,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "api-workload" target port.
port: "api" port: "80"
weight: 50 weight: 50
- backendRef: - backendRef:
ref: ref:
@ -335,7 +339,7 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
# The configuration targets the workload port, not the service port. # The virtual port number for the "admin-workload" target port.
port: "admin" port: "90"
weight: 50 weight: 50
``` ```

View File

@ -34,13 +34,7 @@ Complete the following steps to implement a split in TCP traffic between two ser
## Define route resource ## Define route resource
The following example splits traffic for the services in the `api` Pod. The following example splits traffic for the `api` service. TCP traffic for services registered to the Consul catalog that are available at the `api-workload` port is split so that 50% of the traffic routes to the service at the `api-workload` port and 50% routes to the service at the `admin-workload` port.
<Tabs>
<Tab heading="Method 1" group="method1">
TCP traffic for services registered to the Consul catalog that are available at the `admin` port is split so that 50% of the traffic routes to the service at the `api` port and 50% routes to the service at the `admin` port.
<CodeBlockConfig filename="api-split.yaml"> <CodeBlockConfig filename="api-split.yaml">
@ -57,7 +51,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
port: "admin" # The virtual port number for the "api-workload" target port.
port: "80"
rules: rules:
- backendRefs: - backendRefs:
- backendRef: - backendRef:
@ -67,7 +62,8 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
port: "api" # The virtual port number for the "api-workload" target port.
port: "80"
weight: 50 weight: 50
- backendRef: - backendRef:
ref: ref:
@ -76,59 +72,12 @@ spec:
groupVersion: v2beta1 groupVersion: v2beta1
kind: Service kind: Service
name: api name: api
port: "admin" # The virtual port number for the "admin-workload" target port.
port: "90"
weight: 50 weight: 50
``` ```
</CodeBlockConfig> </CodeBlockConfig>
</Tab>
<Tab heading="Method 2" group="method2">
TCP traffic for services registered to the Consul catalog that are available at the `api-admin` port is split so that 50% of the traffic routes to the service at the `api` port and 50% routes to the service at the `api-admin` port.
<CodeBlockConfig filename="api-split.yaml">
```yaml
apiVersion: mesh.consul.hashicorp.com/v2beta1
kind: TCPRoute
metadata:
name: api-split
spec:
parentRefs:
- ref:
type:
group: catalog
groupVersion: v2beta1
kind: Service
name: api-admin
port: "admin"
rules:
- backendRefs:
- backendRef:
ref:
type:
group: catalog
groupVersion: v2beta1
kind: Service
name: api
port: "api"
weight: 50
- backendRef:
ref:
type:
group: catalog
groupVersion: v2beta1
kind: Service
name: api-admin
port: "admin"
weight: 50
```
</CodeBlockConfig>
</Tab>
</Tabs>
## Apply the resource ## Apply the resource