mirror of https://github.com/hashicorp/consul
[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)pull/20732/head
parent
16a0800777
commit
50b442f7f2
|
@ -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"
|
||||||
```
|
```
|
|
@ -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"
|
||||||
```
|
```
|
|
@ -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
|
||||||
```
|
```
|
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue