mirror of https://github.com/hashicorp/consul
Backport of docs: Dataplane performance impact into release/1.14.x (#15575)
* no-op commit due to failed cherry-picking * docs: Dataplane performance impact (#15566) * New image + performance considerations * Image related updates * Update website/content/docs/connect/dataplane/index.mdx Co-authored-by: David Yu <dyu@hashicorp.com> Co-authored-by: David Yu <dyu@hashicorp.com> Co-authored-by: temp <temp@hashicorp.com> Co-authored-by: Jeff Boruszak <104028618+boruszak@users.noreply.github.com> Co-authored-by: David Yu <dyu@hashicorp.com>pull/15582/head
parent
dc08f05120
commit
3d2f28512a
|
@ -17,7 +17,18 @@ In standard deployments, Consul uses a control plane that contains both _server
|
|||
|
||||
Consul Dataplane manages Envoy proxies and leaves responsibility for other functions to the orchestrator. As a result, it removes the need to run client agents on every pod. In addition, services no longer need to be reregistered to a local client agent after restarting a service instance, as a client agent’s lack of access to persistent data storage in Kubernetes deployments is no longer an issue.
|
||||
|
||||
![Diagram of Consul Dataplanes in Kubernetes deployment](/img/dataplanes-diagram.png)
|
||||
![Diagram of Consul Dataplanes in Kubernetes deployment](/img/k8s-dataplanes-architecture.png)
|
||||
|
||||
### Impact on performance
|
||||
|
||||
The most significant differences between traditional deployments and Consul Dataplane deployments result from the removal of node-level client agents with gossip communication. They are replaced by _dataplanes_, which are the sidecars injected alongside each service instance that handle communication between Consul servers and Envoy proxies.
|
||||
|
||||
Be aware of the following changes and their impact on your network's performance:
|
||||
|
||||
1. Consul servers consume additional resources in order to generate xDS resources for Envoy proxies. In our internal load tests, performing at high scale and churn resulted in additional CPU utilization rates under 10% on the control plane.
|
||||
1. As you deploy more services, the resource usage for dataplanes grows on a linear scale.
|
||||
1. Envoy reconfigurations are rate limited to prevent excessive configuration changes from generating significant load on the servers.
|
||||
1. The frequency of the orchestrator's liveness and readiness probes determine how quickly Consul's control plane can become aware of failures. There is no impact on service mesh applications, however, as Envoy proxies have a passive ability to detect endpoint failure and steer traffic to healthy instances.
|
||||
|
||||
## Benefits
|
||||
|
||||
|
@ -74,5 +85,4 @@ Consul Dataplane supports the following features:
|
|||
|
||||
Be aware of the following limitations and recommendations for Consul Dataplane:
|
||||
|
||||
- Consul API Gateway is not currently supported.
|
||||
- Consul Dataplane is not supported on Windows.
|
||||
|
|
|
@ -41,7 +41,7 @@ so this must done manually when removing servers.
|
|||
|
||||
By default, Consul on Kubernetes uses an alternate service mesh configuration that injects sidecars without client agents. _Consul Dataplane_ manages Envoy proxies and leaves responsibility for other functions to the orchestrator, which removes the need to run client agents on every pod.
|
||||
|
||||
![Diagram of Consul Dataplanes in Kubernetes deployment](/img/dataplanes-diagram.png)
|
||||
![Diagram of Consul Dataplanes in Kubernetes deployment](/img/k8s-dataplanes-architecture.png)
|
||||
|
||||
Refer to [Simplified Service Mesh with Consul Dataplanes](/docs/connect/dataplane/index) for more information.
|
||||
|
||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 168 KiB |
Binary file not shown.
After Width: | Height: | Size: 187 KiB |
Loading…
Reference in New Issue