rancher-partner-charts/charts/linkerd/linkerd-control-plane/README.md

27 KiB

linkerd-control-plane

Linkerd gives you observability, reliability, and security for your microservices — with no code change required.

Version: 1.15.0 Type: application AppVersion: edge-XX.X.X

Homepage: https://linkerd.io

Quickstart and documentation

You can run Linkerd on any Kubernetes 1.21+ cluster in a matter of seconds. See the Linkerd Getting Started Guide for how.

For more comprehensive documentation, start with the Linkerd docs.

Prerequisite: linkerd-crds chart

Before installing this chart, please install the linkerd-crds chart, which creates all the CRDs that the components from the current chart require.

Prerequisite: identity certificates

The identity component of Linkerd requires setting up a trust anchor certificate, and an issuer certificate with its key. These need to be provided to Helm by the user (unlike when using the linkerd install CLI which can generate these automatically). You can provide your own, or follow these instructions to generate new ones.

Alternatively, both trust anchor and identity issuer certificates may be derived from in-cluster resources. Existing CA (trust anchor) certificates must live in a ConfigMap resource named linkerd-identity-trust-roots. Issuer certificates must live in a Secret named linkerd-identity-issuer. Both resources should exist in the control-plane's install namespace. In order to use an existing CA, Linkerd needs to be installed with identity.externalCA=true. To use an existing issuer certificate, Linkerd should be installed with identity.issuer.scheme=kubernetes.io/tls.

A more comprehensive description is in the automatic certificate rotation guide.

Note that the provided certificates must be ECDSA certificates.

Adding Linkerd's Helm repository

Included here for completeness-sake, but should have already been added when linkerd-base was installed.

# To add the repo for Linkerd stable releases:
helm repo add linkerd https://helm.linkerd.io/stable
# To add the repo for Linkerd edge releases:
helm repo add linkerd-edge https://helm.linkerd.io/edge

The following instructions use the linkerd repo. For installing an edge release, just replace with linkerd-edge.

Installing the chart

You must provide the certificates and keys described in the preceding section, and the same expiration date you used to generate the Issuer certificate.

helm install linkerd-control-plane -n linkerd \
  --set-file identityTrustAnchorsPEM=ca.crt \
  --set-file identity.issuer.tls.crtPEM=issuer.crt \
  --set-file identity.issuer.tls.keyPEM=issuer.key \
  linkerd/linkerd-control-plane

Note that you require to install this chart in the same namespace you installed the linkerd-base chart.

Setting High-Availability

Besides the default values.yaml file, the chart provides a values-ha.yaml file that overrides some default values as to set things up under a high-availability scenario, analogous to the --ha option in linkerd install. Values such as higher number of replicas, higher memory/cpu limits and affinities are specified in that file.

You can get ahold of values-ha.yaml by fetching the chart files:

helm fetch --untar linkerd/linkerd-control-plane

Then use the -f flag to provide the override file, for example:

helm install linkerd-control-plane -n linkerd \
  --set-file identityTrustAnchorsPEM=ca.crt \
  --set-file identity.issuer.tls.crtPEM=issuer.crt \
  --set-file identity.issuer.tls.keyPEM=issuer.key \
  -f linkerd2/values-ha.yaml
  linkerd/linkerd-control-plane

Get involved

Extensions for Linkerd

The current chart installs the core Linkerd components, which grant you reliability and security features. Other functionality is available through extensions. Check the corresponding docs for each one of the following extensions:

Requirements

Kubernetes: >=1.21.0-0

Repository Name Version
file://../partials partials 0.1.0

Values

Key Type Default Description
clusterDomain string "cluster.local" Kubernetes DNS Domain name to use
clusterNetworks string "10.0.0.0/8,100.64.0.0/10,172.16.0.0/12,192.168.0.0/16" The cluster networks for which service discovery is performed. This should include the pod and service networks, but need not include the node network. By default, all private networks are specified so that resolution works in typical Kubernetes environments.
cniEnabled bool false enabling this omits the NET_ADMIN capability in the PSP and the proxy-init container when injecting the proxy; requires the linkerd-cni plugin to already be installed
commonLabels object {} Labels to apply to all resources
controlPlaneTracing bool false enables control plane tracing
controlPlaneTracingNamespace string "linkerd-jaeger" namespace to send control plane traces to
controllerImage string "cr.l5d.io/linkerd/controller" Docker image for the destination and identity components
controllerLogFormat string "plain" Log format for the control plane components
controllerLogLevel string "info" Log level for the control plane components
controllerReplicas int 1 Number of replicas for each control plane pod
controllerUID int 2103 User ID for the control plane components
debugContainer.image.name string "cr.l5d.io/linkerd/debug" Docker image for the debug container
debugContainer.image.pullPolicy string imagePullPolicy Pull policy for the debug container Docker image
debugContainer.image.version string linkerdVersion Tag for the debug container Docker image
deploymentStrategy object {"rollingUpdate":{"maxSurge":"25%","maxUnavailable":"25%"}} default kubernetes deployment strategy
disableHeartBeat bool false Set to true to not start the heartbeat cronjob
enableEndpointSlices bool true enables the use of EndpointSlice informers for the destination service; enableEndpointSlices should be set to true only if EndpointSlice K8s feature gate is on
enableH2Upgrade bool true Allow proxies to perform transparent HTTP/2 upgrading
enablePSP bool false Add a PSP resource and bind it to the control plane ServiceAccounts. Note PSP has been deprecated since k8s v1.21
enablePodAntiAffinity bool false enables pod anti affinity creation on deployments for high availability
enablePodDisruptionBudget bool false enables the creation of pod disruption budgets for control plane components
enablePprof bool false enables the use of pprof endpoints on control plane component's admin servers
identity.externalCA bool false If the linkerd-identity-trust-roots ConfigMap has already been created
identity.issuer.clockSkewAllowance string "20s" Amount of time to allow for clock skew within a Linkerd cluster
identity.issuer.issuanceLifetime string "24h0m0s" Amount of time for which the Identity issuer should certify identity
identity.issuer.scheme string "linkerd.io/tls"
identity.issuer.tls object {"crtPEM":"","keyPEM":""} Which scheme is used for the identity issuer secret format
identity.issuer.tls.crtPEM string "" Issuer certificate (ECDSA). It must be provided during install.
identity.issuer.tls.keyPEM string "" Key for the issuer certificate (ECDSA). It must be provided during install
identity.serviceAccountTokenProjection bool true Use Service Account token Volume projection for pod validation instead of the default token
identityTrustAnchorsPEM string "" Trust root certificate (ECDSA). It must be provided during install.
identityTrustDomain string clusterDomain Trust domain used for identity
imagePullPolicy string "IfNotPresent" Docker image pull policy
imagePullSecrets list [] For Private docker registries, authentication is needed. Registry secrets are applied to the respective service accounts
linkerdVersion string "linkerdVersionValue" control plane version. See Proxy section for proxy version
networkValidator.connectAddr string "1.1.1.1:20001" Address to which the network-validator will attempt to connect. we expect this to be rewritten
networkValidator.enableSecurityContext bool true Include a securityContext in the network-validator pod spec
networkValidator.listenAddr string "0.0.0.0:4140" Address to which network-validator listens to requests from itself
networkValidator.logFormat string plain Log format (plain or json) for network-validator
networkValidator.logLevel string debug Log level for the network-validator
networkValidator.timeout string "10s" Timeout before network-validator fails to validate the pod's network connectivity
nodeSelector object {"kubernetes.io/os":"linux"} NodeSelector section, See the K8S documentation for more information
podAnnotations object {} Additional annotations to add to all pods
podLabels object {} Additional labels to add to all pods
podMonitor.controller.enabled bool true Enables the creation of PodMonitor for the control-plane
podMonitor.controller.namespaceSelector string "matchNames:\n - {{ .Release.Namespace }}\n - linkerd-viz\n - linkerd-jaeger\n" Selector to select which namespaces the Endpoints objects are discovered from
podMonitor.enabled bool false Enables the creation of Prometheus Operator PodMonitor
podMonitor.proxy.enabled bool true Enables the creation of PodMonitor for the data-plane
podMonitor.scrapeInterval string "10s" Interval at which metrics should be scraped
podMonitor.scrapeTimeout string "10s" Iimeout after which the scrape is ended
podMonitor.serviceMirror.enabled bool true Enables the creation of PodMonitor for the Service Mirror component
policyController.image.name string "cr.l5d.io/linkerd/policy-controller" Docker image for the policy controller
policyController.image.pullPolicy string imagePullPolicy Pull policy for the proxy container Docker image
policyController.image.version string linkerdVersion Tag for the proxy container Docker image
policyController.logLevel string "info" Log level for the policy controller
policyController.probeNetworks list ["0.0.0.0/0"] The networks from which probes are performed. By default, all networks are allowed so that all probes are authorized.
policyController.resources object destinationResources policy controller resource requests & limits
policyController.resources.cpu.limit string "" Maximum amount of CPU units that the policy controller can use
policyController.resources.cpu.request string "" Amount of CPU units that the policy controller requests
policyController.resources.ephemeral-storage.limit string "" Maximum amount of ephemeral storage that the policy controller can use
policyController.resources.ephemeral-storage.request string "" Amount of ephemeral storage that the policy controller requests
policyController.resources.memory.limit string "" Maximum amount of memory that the policy controller can use
policyController.resources.memory.request string "" Maximum amount of memory that the policy controller requests
policyValidator.caBundle string "" Bundle of CA certificates for proxy injector. If not provided nor injected with cert-manager, then Helm will use the certificate generated for policyValidator.crtPEM. If policyValidator.externalSecret is set to true, this value, injectCaFrom, or injectCaFromSecret must be set, as no certificate will be generated. See the cert-manager CA Injector Docs for more information.
policyValidator.crtPEM string "" Certificate for the policy validator. If not provided and not using an external secret then Helm will generate one.
policyValidator.externalSecret bool false Do not create a secret resource for the policyValidator webhook. If this is set to true, the value policyValidator.caBundle must be set or the ca bundle must injected with cert-manager ca injector using policyValidator.injectCaFrom or policyValidator.injectCaFromSecret (see below).
policyValidator.injectCaFrom string "" Inject the CA bundle from a cert-manager Certificate. See the cert-manager CA Injector Docs for more information.
policyValidator.injectCaFromSecret string "" Inject the CA bundle from a Secret. If set, the cert-manager.io/inject-ca-from-secret annotation will be added to the webhook. The Secret must have the CA Bundle stored in the ca.crt key and have the cert-manager.io/allow-direct-injection annotation set to true. See the cert-manager CA Injector Docs for more information.
policyValidator.keyPEM string "" Certificate key for the policy validator. If not provided and not using an external secret then Helm will generate one.
policyValidator.namespaceSelector object {"matchExpressions":[{"key":"config.linkerd.io/admission-webhooks","operator":"NotIn","values":["disabled"]}]} Namespace selector used by admission webhook
priorityClassName string "" Kubernetes priorityClassName for the Linkerd Pods
profileValidator.caBundle string "" Bundle of CA certificates for proxy injector. If not provided nor injected with cert-manager, then Helm will use the certificate generated for profileValidator.crtPEM. If profileValidator.externalSecret is set to true, this value, injectCaFrom, or injectCaFromSecret must be set, as no certificate will be generated. See the cert-manager CA Injector Docs for more information.
profileValidator.crtPEM string "" Certificate for the service profile validator. If not provided and not using an external secret then Helm will generate one.
profileValidator.externalSecret bool false Do not create a secret resource for the profileValidator webhook. If this is set to true, the value proxyInjector.caBundle must be set or the ca bundle must injected with cert-manager ca injector using proxyInjector.injectCaFrom or proxyInjector.injectCaFromSecret (see below).
profileValidator.injectCaFrom string "" Inject the CA bundle from a cert-manager Certificate. See the cert-manager CA Injector Docs for more information.
profileValidator.injectCaFromSecret string "" Inject the CA bundle from a Secret. If set, the cert-manager.io/inject-ca-from-secret annotation will be added to the webhook. The Secret must have the CA Bundle stored in the ca.crt key and have the cert-manager.io/allow-direct-injection annotation set to true. See the cert-manager CA Injector Docs for more information.
profileValidator.keyPEM string "" Certificate key for the service profile validator. If not provided and not using an external secret then Helm will generate one.
profileValidator.namespaceSelector object {"matchExpressions":[{"key":"config.linkerd.io/admission-webhooks","operator":"NotIn","values":["disabled"]}]} Namespace selector used by admission webhook
proxy.await bool true If set, the application container will not start until the proxy is ready
proxy.cores int 0 The cpu.limit and cores should be kept in sync. The value of cores must be an integer and should typically be set by rounding up from the limit. E.g. if cpu.limit is '1500m', cores should be 2.
proxy.defaultInboundPolicy string "all-unauthenticated" The default allow policy to use when no Server selects a pod. One of: "all-authenticated", "all-unauthenticated", "cluster-authenticated", "cluster-unauthenticated", "deny"
proxy.enableExternalProfiles bool false Enable service profiles for non-Kubernetes services
proxy.image.name string "cr.l5d.io/linkerd/proxy" Docker image for the proxy
proxy.image.pullPolicy string imagePullPolicy Pull policy for the proxy container Docker image
proxy.image.version string linkerdVersion Tag for the proxy container Docker image
proxy.inboundConnectTimeout string "100ms" Maximum time allowed for the proxy to establish an inbound TCP connection
proxy.inboundDiscoveryCacheUnusedTimeout string "90s" Maximum time allowed before an unused inbound discovery result is evicted from the cache
proxy.logFormat string "plain" Log format (plain or json) for the proxy
proxy.logLevel string "warn,linkerd=info,trust_dns=error" Log level for the proxy
proxy.opaquePorts string "25,587,3306,4444,5432,6379,9300,11211" Default set of opaque ports - SMTP (25,587) server-first - MYSQL (3306) server-first - Galera (4444) server-first - PostgreSQL (5432) server-first - Redis (6379) server-first - ElasticSearch (9300) server-first - Memcached (11211) clients do not issue any preamble, which breaks detection
proxy.outboundConnectTimeout string "1000ms" Maximum time allowed for the proxy to establish an outbound TCP connection
proxy.outboundDiscoveryCacheUnusedTimeout string "5s" Maximum time allowed before an unused outbound discovery result is evicted from the cache
proxy.ports.admin int 4191 Admin port for the proxy container
proxy.ports.control int 4190 Control port for the proxy container
proxy.ports.inbound int 4143 Inbound port for the proxy container
proxy.ports.outbound int 4140 Outbound port for the proxy container
proxy.requireIdentityOnInboundPorts string ""
proxy.resources.cpu.limit string "" Maximum amount of CPU units that the proxy can use
proxy.resources.cpu.request string "" Amount of CPU units that the proxy requests
proxy.resources.ephemeral-storage.limit string "" Maximum amount of ephemeral storage that the proxy can use
proxy.resources.ephemeral-storage.request string "" Amount of ephemeral storage that the proxy requests
proxy.resources.memory.limit string "" Maximum amount of memory that the proxy can use
proxy.resources.memory.request string "" Maximum amount of memory that the proxy requests
proxy.shutdownGracePeriod string "" Grace period for graceful proxy shutdowns. If this timeout elapses before all open connections have completed, the proxy will terminate forcefully, closing any remaining connections.
proxy.uid int 2102 User id under which the proxy runs
proxy.waitBeforeExitSeconds int 0 If set the injected proxy sidecars in the data plane will stay alive for at least the given period before receiving the SIGTERM signal from Kubernetes but no longer than the pod's terminationGracePeriodSeconds. See Lifecycle hooks for more info on container lifecycle hooks.
proxyInit.closeWaitTimeoutSecs int 0
proxyInit.ignoreInboundPorts string "4567,4568" Default set of inbound ports to skip via iptables - Galera (4567,4568)
proxyInit.ignoreOutboundPorts string "4567,4568" Default set of outbound ports to skip via iptables - Galera (4567,4568)
proxyInit.image.name string "cr.l5d.io/linkerd/proxy-init" Docker image for the proxy-init container
proxyInit.image.pullPolicy string imagePullPolicy Pull policy for the proxy-init container Docker image
proxyInit.image.version string "v2.2.1" Tag for the proxy-init container Docker image
proxyInit.iptablesMode string "legacy" Variant of iptables that will be used to configure routing. Currently, proxy-init can be run either in 'nft' or in 'legacy' mode. The mode will control which utility binary will be called. The host must support whichever mode will be used
proxyInit.kubeAPIServerPorts string "443,6443" Default set of ports to skip via iptables for control plane components so they can communicate with the Kubernetes API Server
proxyInit.logFormat string plain Log format (plain or json) for the proxy-init
proxyInit.logLevel string info Log level for the proxy-init
proxyInit.privileged bool false Privileged mode allows the container processes to inherit all security capabilities and bypass any security limitations enforced by the kubelet. When used with 'runAsRoot: true', the container will behave exactly as if it was running as root on the host. May escape cgroup limits and see other processes and devices on the host.
proxyInit.resources.cpu.limit string "100m" Maximum amount of CPU units that the proxy-init container can use
proxyInit.resources.cpu.request string "100m" Amount of CPU units that the proxy-init container requests
proxyInit.resources.ephemeral-storage.limit string "" Maximum amount of ephemeral storage that the proxy-init container can use
proxyInit.resources.ephemeral-storage.request string "" Amount of ephemeral storage that the proxy-init container requests
proxyInit.resources.memory.limit string "20Mi" Maximum amount of memory that the proxy-init container can use
proxyInit.resources.memory.request string "20Mi" Amount of memory that the proxy-init container requests
proxyInit.runAsRoot bool false Allow overriding the runAsNonRoot behaviour (https://github.com/linkerd/linkerd2/issues/7308)
proxyInit.runAsUser int 65534 This value is used only if runAsRoot is false; otherwise runAsUser will be 0
proxyInit.skipSubnets string "" Comma-separated list of subnets in valid CIDR format that should be skipped by the proxy
proxyInit.xtMountPath.mountPath string "/run"
proxyInit.xtMountPath.name string "linkerd-proxy-init-xtables-lock"
proxyInjector.caBundle string "" Bundle of CA certificates for proxy injector. If not provided nor injected with cert-manager, then Helm will use the certificate generated for proxyInjector.crtPEM. If proxyInjector.externalSecret is set to true, this value, injectCaFrom, or injectCaFromSecret must be set, as no certificate will be generated. See the cert-manager CA Injector Docs for more information.
proxyInjector.crtPEM string "" Certificate for the proxy injector. If not provided and not using an external secret then Helm will generate one.
proxyInjector.externalSecret bool false Do not create a secret resource for the proxyInjector webhook. If this is set to true, the value proxyInjector.caBundle must be set or the ca bundle must injected with cert-manager ca injector using proxyInjector.injectCaFrom or proxyInjector.injectCaFromSecret (see below).
proxyInjector.injectCaFrom string "" Inject the CA bundle from a cert-manager Certificate. See the cert-manager CA Injector Docs for more information.
proxyInjector.injectCaFromSecret string "" Inject the CA bundle from a Secret. If set, the cert-manager.io/inject-ca-from-secret annotation will be added to the webhook. The Secret must have the CA Bundle stored in the ca.crt key and have the cert-manager.io/allow-direct-injection annotation set to true. See the cert-manager CA Injector Docs for more information.
proxyInjector.keyPEM string "" Certificate key for the proxy injector. If not provided and not using an external secret then Helm will generate one.
proxyInjector.namespaceSelector object {"matchExpressions":[{"key":"config.linkerd.io/admission-webhooks","operator":"NotIn","values":["disabled"]},{"key":"kubernetes.io/metadata.name","operator":"NotIn","values":["kube-system","cert-manager"]}]} Namespace selector used by admission webhook.
proxyInjector.objectSelector object {"matchExpressions":[{"key":"linkerd.io/control-plane-component","operator":"DoesNotExist"},{"key":"linkerd.io/cni-resource","operator":"DoesNotExist"}]} Object selector used by admission webhook.
runtimeClassName string "" Runtime Class Name for all the pods
webhookFailurePolicy string "Ignore" Failure policy for the proxy injector

Autogenerated from chart metadata using helm-docs v1.11.0