make charts
parent
b6778e78a1
commit
41c52a9b9f
Binary file not shown.
|
@ -0,0 +1,22 @@
|
||||||
|
# Patterns to ignore when building packages.
|
||||||
|
# This supports shell glob matching, relative path matching, and
|
||||||
|
# negation (prefixed with !). Only one pattern per line.
|
||||||
|
.DS_Store
|
||||||
|
OWNERS
|
||||||
|
# Common VCS dirs
|
||||||
|
.git/
|
||||||
|
.gitignore
|
||||||
|
.bzr/
|
||||||
|
.bzrignore
|
||||||
|
.hg/
|
||||||
|
.hgignore
|
||||||
|
.svn/
|
||||||
|
# Common backup files
|
||||||
|
*.swp
|
||||||
|
*.bak
|
||||||
|
*.tmp
|
||||||
|
*~
|
||||||
|
# Various IDEs
|
||||||
|
.project
|
||||||
|
.idea/
|
||||||
|
*.tmproj
|
|
@ -0,0 +1,22 @@
|
||||||
|
annotations:
|
||||||
|
catalog.cattle.io/certified: partner
|
||||||
|
catalog.cattle.io/display-name: Linkerd
|
||||||
|
catalog.cattle.io/release-name: linkerd
|
||||||
|
apiVersion: v1
|
||||||
|
appVersion: stable-2.11.0
|
||||||
|
description: |
|
||||||
|
Linkerd gives you observability, reliability, and security
|
||||||
|
for your microservices — with no code change required.
|
||||||
|
home: https://linkerd.io
|
||||||
|
icon: https://linkerd.io/images/logo-only-200h.png
|
||||||
|
keywords:
|
||||||
|
- service-mesh
|
||||||
|
kubeVersion: '>=1.16.0-0'
|
||||||
|
maintainers:
|
||||||
|
- email: cncf-linkerd-dev@lists.cncf.io
|
||||||
|
name: Linkerd authors
|
||||||
|
url: https://linkerd.io/
|
||||||
|
name: linkerd2
|
||||||
|
sources:
|
||||||
|
- https://github.com/linkerd/linkerd2/
|
||||||
|
version: 2.11.0
|
|
@ -0,0 +1,226 @@
|
||||||
|
# linkerd2
|
||||||
|
|
||||||
|
Linkerd gives you observability, reliability, and security
|
||||||
|
for your microservices — with no code change required.
|
||||||
|
|
||||||
|
![Version: 0.1.0](https://img.shields.io/badge/Version-0.1.0-informational?style=flat-square)
|
||||||
|
|
||||||
|
![AppVersion: edge-XX.X.X](https://img.shields.io/badge/AppVersion-edge--XX.X.X-informational?style=flat-square)
|
||||||
|
|
||||||
|
**Homepage:** <https://linkerd.io>
|
||||||
|
|
||||||
|
## Quickstart and documentation
|
||||||
|
|
||||||
|
You can run Linkerd on any Kubernetes 1.16+ cluster in a matter of seconds. See
|
||||||
|
the [Linkerd Getting Started Guide][getting-started] for how.
|
||||||
|
|
||||||
|
For more comprehensive documentation, start with the [Linkerd
|
||||||
|
docs][linkerd-docs].
|
||||||
|
|
||||||
|
## 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](https://linkerd.io/2/tasks/generate-certificates/) to generate new
|
||||||
|
ones.
|
||||||
|
|
||||||
|
Note that the provided certificates must be ECDSA certificates.
|
||||||
|
|
||||||
|
## Adding Linkerd's Helm repository
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# To add the repo for Linkerd2 stable releases:
|
||||||
|
helm repo add linkerd https://helm.linkerd.io/stable
|
||||||
|
# To add the repo for Linkerd2 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.
|
||||||
|
|
||||||
|
In this example we set the expiration date to one year ahead:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
helm install \
|
||||||
|
--set-file identityTrustAnchorsPEM=ca.crt \
|
||||||
|
--set-file identity.issuer.tls.crtPEM=issuer.crt \
|
||||||
|
--set-file identity.issuer.tls.keyPEM=issuer.key \
|
||||||
|
--set identity.issuer.crtExpiry=$(date -d '+8760 hour' +"%Y-%m-%dT%H:%M:%SZ") \
|
||||||
|
linkerd/linkerd2
|
||||||
|
```
|
||||||
|
|
||||||
|
## 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:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
helm fetch --untar linkerd/linkerd2
|
||||||
|
```
|
||||||
|
|
||||||
|
Then use the `-f` flag to provide the override file, for example:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
helm install \
|
||||||
|
--set-file identityTrustAnchorsPEM=ca.crt \
|
||||||
|
--set-file identity.issuer.tls.crtPEM=issuer.crt \
|
||||||
|
--set-file identity.issuer.tls.keyPEM=issuer.key \
|
||||||
|
--set identity.issuer.crtExpiry=$(date -d '+8760 hour' +"%Y-%m-%dT%H:%M:%SZ") \
|
||||||
|
-f linkerd2/values-ha.yaml
|
||||||
|
linkerd/linkerd2
|
||||||
|
```
|
||||||
|
|
||||||
|
## Get involved
|
||||||
|
|
||||||
|
* Check out Linkerd's source code at [GitHub][linkerd2].
|
||||||
|
* Join Linkerd's [user mailing list][linkerd-users], [developer mailing
|
||||||
|
list][linkerd-dev], and [announcements mailing list][linkerd-announce].
|
||||||
|
* Follow [@linkerd][twitter] on Twitter.
|
||||||
|
* Join the [Linkerd Slack][slack].
|
||||||
|
|
||||||
|
[cncf]: https://www.cncf.io/
|
||||||
|
[getting-started]: https://linkerd.io/2/getting-started/
|
||||||
|
[linkerd2]: https://github.com/linkerd/linkerd2
|
||||||
|
[linkerd-announce]: https://lists.cncf.io/g/cncf-linkerd-announce
|
||||||
|
[linkerd-dev]: https://lists.cncf.io/g/cncf-linkerd-dev
|
||||||
|
[linkerd-docs]: https://linkerd.io/2/overview/
|
||||||
|
[linkerd-users]: https://lists.cncf.io/g/cncf-linkerd-users
|
||||||
|
[slack]: http://slack.linkerd.io
|
||||||
|
[twitter]: https://twitter.com/linkerd
|
||||||
|
|
||||||
|
## 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:
|
||||||
|
|
||||||
|
* Observability:
|
||||||
|
[Linkerd-viz](https://github.com/linkerd/linkerd2/blob/main/viz/charts/linkerd-viz/README.md)
|
||||||
|
* Multicluster:
|
||||||
|
[Linkerd-multicluster](https://github.com/linkerd/linkerd2/blob/main/multicluster/charts/linkerd-multicluster/README.md)
|
||||||
|
* Tracing:
|
||||||
|
[Linkerd-jaeger](https://github.com/linkerd/linkerd2/blob/main/jaeger/charts/linkerd-jaeger/README.md)
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
Kubernetes: `>=1.16.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 |
|
||||||
|
| 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 |
|
||||||
|
| disableHeartBeat | bool | `false` | Set to true to not start the heartbeat cronjob |
|
||||||
|
| enableEndpointSlices | bool | `false` | enables the use of EndpointSlice informers for the destination service; enableEndpointSlices should be set to true only if EndpointSlice K8s feature gate is on; the feature is still experimental. |
|
||||||
|
| 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 |
|
||||||
|
| 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.crtExpiry | string | `nil` | Expiration timestamp for the issuer certificate. It must be provided during install. Must match the expiry date in crtPEM |
|
||||||
|
| 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 |
|
||||||
|
| 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 |
|
||||||
|
| installNamespace | bool | `true` | Set to false when installing Linkerd in a custom namespace. See the [Linkerd documentation](https://linkerd.io/2/tasks/install-helm#customizing-the-namespace) for more information. |
|
||||||
|
| linkerdVersion | string | `"linkerdVersionValue"` | control plane version. See Proxy section for proxy version |
|
||||||
|
| namespace | string | `"linkerd"` | Control plane namespace |
|
||||||
|
| nodeSelector | object | `{"beta.kubernetes.io/os":"linux"}` | NodeSelector section, See the [K8S documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#nodeselector) for more information |
|
||||||
|
| podAnnotations | object | `{}` | Additional annotations to add to all pods |
|
||||||
|
| podLabels | object | `{}` | Additional labels to add to all pods |
|
||||||
|
| policyController.defaultAllowPolicy | 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" |
|
||||||
|
| policyController.image.name | string | `"cr.l5d.io/linkerd/policy-controller"` | Docker image for the proxy |
|
||||||
|
| 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 | `"linkerd=info,warn"` | Log level for the policy controller |
|
||||||
|
| 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.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 policy validator. If not provided then Helm will use the certificate generated for `policyValidator.crtPEM`. If `policyValidator.externalSecret` is set to true, this value must be set, as no certificate will be generated. |
|
||||||
|
| policyValidator.crtPEM | string | `""` | Certificate for the policy validator. If not provided 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 (see below). |
|
||||||
|
| policyValidator.keyPEM | string | `""` | Certificate key for the policy validator. If not provided 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 |
|
||||||
|
| profileValidator.caBundle | string | `""` | Bundle of CA certificates for service profile validator. If not provided then Helm will use the certificate generated for `profileValidator.crtPEM`. If `profileValidator.externalSecret` is set to true, this value must be set, as no certificate will be generated. |
|
||||||
|
| profileValidator.crtPEM | string | `""` | Certificate for the service profile validator. If not provided 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 `profileValidator.caBundle` must be set (see below). |
|
||||||
|
| profileValidator.keyPEM | string | `""` | Certificate key for the service profile validator. If not provided 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.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.logFormat | string | `"plain"` | Log format (`plain` or `json`) for the proxy |
|
||||||
|
| proxy.logLevel | string | `"warn,linkerd=info"` | 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.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.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.uid | int | `2102` | User id under which the proxy runs |
|
||||||
|
| proxy.waitBeforeExitSeconds | int | `0` | If set the proxy sidecar will stay alive for at least the given period before receiving SIGTERM signal from Kubernetes but no longer than pod's `terminationGracePeriodSeconds`. See [Lifecycle hooks](https://kubernetes.io/docs/concepts/containers/container-lifecycle-hooks/#container-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 | `"v1.4.0"` | Tag for the proxy-init container Docker image |
|
||||||
|
| proxyInit.resources.cpu.limit | string | `"100m"` | Maximum amount of CPU units that the proxy-init container can use |
|
||||||
|
| proxyInit.resources.cpu.request | string | `"10m"` | Amount of CPU units that the proxy-init container requests |
|
||||||
|
| proxyInit.resources.memory.limit | string | `"50Mi"` | Maximum amount of memory that the proxy-init container can use |
|
||||||
|
| proxyInit.resources.memory.request | string | `"10Mi"` | Amount of memory that the proxy-init container requests |
|
||||||
|
| 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 then Helm will use the certificate generated for `proxyInjector.crtPEM`. If `proxyInjector.externalSecret` is set to true, this value must be set, as no certificate will be generated. |
|
||||||
|
| proxyInjector.crtPEM | string | `""` | Certificate for the proxy injector. If not provided then Helm will generate one. |
|
||||||
|
| proxyInjector.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 (see below) |
|
||||||
|
| proxyInjector.keyPEM | string | `""` | Certificate key for the proxy injector. If not provided then Helm will generate one. |
|
||||||
|
| proxyInjector.namespaceSelector | object | `{"matchExpressions":[{"key":"config.linkerd.io/admission-webhooks","operator":"NotIn","values":["disabled"]}]}` | Namespace selector used by admission webhook. If not set defaults to all namespaces without the annotation config.linkerd.io/admission-webhooks=disabled |
|
||||||
|
| webhookFailurePolicy | string | `"Ignore"` | Failure policy for the proxy injector |
|
||||||
|
|
||||||
|
----------------------------------------------
|
||||||
|
Autogenerated from chart metadata using [helm-docs v1.4.0](https://github.com/norwoodj/helm-docs/releases/v1.4.0)
|
|
@ -0,0 +1,119 @@
|
||||||
|
{{ template "chart.header" . }}
|
||||||
|
{{ template "chart.description" . }}
|
||||||
|
|
||||||
|
{{ template "chart.versionBadge" . }}
|
||||||
|
{{ template "chart.typeBadge" . }}
|
||||||
|
{{ template "chart.appVersionBadge" . }}
|
||||||
|
|
||||||
|
{{ template "chart.homepageLine" . }}
|
||||||
|
|
||||||
|
## Quickstart and documentation
|
||||||
|
|
||||||
|
You can run Linkerd on any Kubernetes 1.16+ cluster in a matter of seconds. See
|
||||||
|
the [Linkerd Getting Started Guide][getting-started] for how.
|
||||||
|
|
||||||
|
For more comprehensive documentation, start with the [Linkerd
|
||||||
|
docs][linkerd-docs].
|
||||||
|
|
||||||
|
## 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](https://linkerd.io/2/tasks/generate-certificates/) to generate new
|
||||||
|
ones.
|
||||||
|
|
||||||
|
Note that the provided certificates must be ECDSA certificates.
|
||||||
|
|
||||||
|
## Adding Linkerd's Helm repository
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# To add the repo for Linkerd2 stable releases:
|
||||||
|
helm repo add linkerd https://helm.linkerd.io/stable
|
||||||
|
# To add the repo for Linkerd2 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.
|
||||||
|
|
||||||
|
In this example we set the expiration date to one year ahead:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
helm install \
|
||||||
|
--set-file identityTrustAnchorsPEM=ca.crt \
|
||||||
|
--set-file identity.issuer.tls.crtPEM=issuer.crt \
|
||||||
|
--set-file identity.issuer.tls.keyPEM=issuer.key \
|
||||||
|
--set identity.issuer.crtExpiry=$(date -d '+8760 hour' +"%Y-%m-%dT%H:%M:%SZ") \
|
||||||
|
linkerd/linkerd2
|
||||||
|
```
|
||||||
|
|
||||||
|
## 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:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
helm fetch --untar linkerd/linkerd2
|
||||||
|
```
|
||||||
|
|
||||||
|
Then use the `-f` flag to provide the override file, for example:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
helm install \
|
||||||
|
--set-file identityTrustAnchorsPEM=ca.crt \
|
||||||
|
--set-file identity.issuer.tls.crtPEM=issuer.crt \
|
||||||
|
--set-file identity.issuer.tls.keyPEM=issuer.key \
|
||||||
|
--set identity.issuer.crtExpiry=$(date -d '+8760 hour' +"%Y-%m-%dT%H:%M:%SZ") \
|
||||||
|
-f linkerd2/values-ha.yaml
|
||||||
|
linkerd/linkerd2
|
||||||
|
```
|
||||||
|
|
||||||
|
## Get involved
|
||||||
|
|
||||||
|
* Check out Linkerd's source code at [GitHub][linkerd2].
|
||||||
|
* Join Linkerd's [user mailing list][linkerd-users], [developer mailing
|
||||||
|
list][linkerd-dev], and [announcements mailing list][linkerd-announce].
|
||||||
|
* Follow [@linkerd][twitter] on Twitter.
|
||||||
|
* Join the [Linkerd Slack][slack].
|
||||||
|
|
||||||
|
[cncf]: https://www.cncf.io/
|
||||||
|
[getting-started]: https://linkerd.io/2/getting-started/
|
||||||
|
[linkerd2]: https://github.com/linkerd/linkerd2
|
||||||
|
[linkerd-announce]: https://lists.cncf.io/g/cncf-linkerd-announce
|
||||||
|
[linkerd-dev]: https://lists.cncf.io/g/cncf-linkerd-dev
|
||||||
|
[linkerd-docs]: https://linkerd.io/2/overview/
|
||||||
|
[linkerd-users]: https://lists.cncf.io/g/cncf-linkerd-users
|
||||||
|
[slack]: http://slack.linkerd.io
|
||||||
|
[twitter]: https://twitter.com/linkerd
|
||||||
|
|
||||||
|
## 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:
|
||||||
|
|
||||||
|
* Observability:
|
||||||
|
[Linkerd-viz](https://github.com/linkerd/linkerd2/blob/main/viz/charts/linkerd-viz/README.md)
|
||||||
|
* Multicluster:
|
||||||
|
[Linkerd-multicluster](https://github.com/linkerd/linkerd2/blob/main/multicluster/charts/linkerd-multicluster/README.md)
|
||||||
|
* Tracing:
|
||||||
|
[Linkerd-jaeger](https://github.com/linkerd/linkerd2/blob/main/jaeger/charts/linkerd-jaeger/README.md)
|
||||||
|
|
||||||
|
{{ template "chart.requirementsSection" . }}
|
||||||
|
|
||||||
|
{{ template "chart.valuesSection" . }}
|
||||||
|
|
||||||
|
{{ template "helm-docs.versionFooter" . }}
|
|
@ -0,0 +1,9 @@
|
||||||
|
# Linkerd 2 Chart
|
||||||
|
|
||||||
|
Linkerd is an ultra light, ultra simple, ultra powerful service mesh. Linkerd
|
||||||
|
adds security, observability, and reliability to Kubernetes, without the
|
||||||
|
complexity.
|
||||||
|
|
||||||
|
This particular chart only installs the control plane core. To gain access to
|
||||||
|
the observability features, please install the linkerd-viz chart. Other
|
||||||
|
extensions are available (multicluster, jaeger) under the linkerd Helm repo.
|
|
@ -0,0 +1,21 @@
|
||||||
|
# Patterns to ignore when building packages.
|
||||||
|
# This supports shell glob matching, relative path matching, and
|
||||||
|
# negation (prefixed with !). Only one pattern per line.
|
||||||
|
.DS_Store
|
||||||
|
# Common VCS dirs
|
||||||
|
.git/
|
||||||
|
.gitignore
|
||||||
|
.bzr/
|
||||||
|
.bzrignore
|
||||||
|
.hg/
|
||||||
|
.hgignore
|
||||||
|
.svn/
|
||||||
|
# Common backup files
|
||||||
|
*.swp
|
||||||
|
*.bak
|
||||||
|
*.tmp
|
||||||
|
*~
|
||||||
|
# Various IDEs
|
||||||
|
.project
|
||||||
|
.idea/
|
||||||
|
*.tmproj
|
|
@ -0,0 +1,6 @@
|
||||||
|
apiVersion: v1
|
||||||
|
description: |
|
||||||
|
A Helm chart containing Linkerd partial templates,
|
||||||
|
depended by the 'linkerd' and 'patch' charts.
|
||||||
|
name: partials
|
||||||
|
version: 0.1.0
|
|
@ -0,0 +1,9 @@
|
||||||
|
# partials
|
||||||
|
|
||||||
|
A Helm chart containing Linkerd partial templates,
|
||||||
|
depended by the 'linkerd' and 'patch' charts.
|
||||||
|
|
||||||
|
![Version: 0.1.0](https://img.shields.io/badge/Version-0.1.0-informational?style=flat-square)
|
||||||
|
|
||||||
|
----------------------------------------------
|
||||||
|
Autogenerated from chart metadata using [helm-docs v1.4.0](https://github.com/norwoodj/helm-docs/releases/v1.4.0)
|
|
@ -0,0 +1,14 @@
|
||||||
|
{{ template "chart.header" . }}
|
||||||
|
{{ template "chart.description" . }}
|
||||||
|
|
||||||
|
{{ template "chart.versionBadge" . }}
|
||||||
|
{{ template "chart.typeBadge" . }}
|
||||||
|
{{ template "chart.appVersionBadge" . }}
|
||||||
|
|
||||||
|
{{ template "chart.homepageLine" . }}
|
||||||
|
|
||||||
|
{{ template "chart.requirementsSection" . }}
|
||||||
|
|
||||||
|
{{ template "chart.valuesSection" . }}
|
||||||
|
|
||||||
|
{{ template "helm-docs.versionFooter" . }}
|
|
@ -0,0 +1,22 @@
|
||||||
|
{{ define "linkerd.pod-affinity" -}}
|
||||||
|
affinity:
|
||||||
|
podAntiAffinity:
|
||||||
|
preferredDuringSchedulingIgnoredDuringExecution:
|
||||||
|
- podAffinityTerm:
|
||||||
|
labelSelector:
|
||||||
|
matchExpressions:
|
||||||
|
- key: {{ default "linkerd.io/control-plane-component" .label }}
|
||||||
|
operator: In
|
||||||
|
values:
|
||||||
|
- {{ .component }}
|
||||||
|
topologyKey: failure-domain.beta.kubernetes.io/zone
|
||||||
|
weight: 100
|
||||||
|
requiredDuringSchedulingIgnoredDuringExecution:
|
||||||
|
- labelSelector:
|
||||||
|
matchExpressions:
|
||||||
|
- key: {{ default "linkerd.io/control-plane-component" .label }}
|
||||||
|
operator: In
|
||||||
|
values:
|
||||||
|
- {{ .component }}
|
||||||
|
topologyKey: kubernetes.io/hostname
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,16 @@
|
||||||
|
{{- define "partials.proxy.capabilities" -}}
|
||||||
|
capabilities:
|
||||||
|
{{- if .Values.proxy.capabilities.add }}
|
||||||
|
add:
|
||||||
|
{{- toYaml .Values.proxy.capabilities.add | trim | nindent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.proxy.capabilities.drop }}
|
||||||
|
drop:
|
||||||
|
{{- toYaml .Values.proxy.capabilities.drop | trim | nindent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "partials.proxy-init.capabilities.drop" -}}
|
||||||
|
drop:
|
||||||
|
{{ toYaml .Values.proxyInit.capabilities.drop | trim }}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,6 @@
|
||||||
|
{{- define "partials.debug" -}}
|
||||||
|
image: {{.Values.debugContainer.image.name}}:{{.Values.debugContainer.image.version | default .Values.linkerdVersion}}
|
||||||
|
imagePullPolicy: {{.Values.debugContainer.image.pullPolicy | default .Values.imagePullPolicy}}
|
||||||
|
name: linkerd-debug
|
||||||
|
terminationMessagePolicy: FallbackToLogsOnError
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,14 @@
|
||||||
|
{{/* vim: set filetype=mustache: */}}
|
||||||
|
{{/*
|
||||||
|
Splits a coma separated list into a list of string values.
|
||||||
|
For example "11,22,55,44" will become "11","22","55","44"
|
||||||
|
*/}}
|
||||||
|
{{- define "partials.splitStringList" -}}
|
||||||
|
{{- if gt (len (toString .)) 0 -}}
|
||||||
|
{{- $ports := toString . | splitList "," -}}
|
||||||
|
{{- $last := sub (len $ports) 1 -}}
|
||||||
|
{{- range $i,$port := $ports -}}
|
||||||
|
"{{$port}}"{{ternary "," "" (ne $i $last)}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,16 @@
|
||||||
|
{{- define "partials.annotations.created-by" -}}
|
||||||
|
linkerd.io/created-by: {{ .Values.cliVersion | default (printf "linkerd/helm %s" (.Values.cniPluginVersion | default .Values.linkerdVersion)) }}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{- define "partials.proxy.annotations" -}}
|
||||||
|
linkerd.io/identity-mode: {{ternary "default" "disabled" (not .Values.proxy.disableIdentity)}}
|
||||||
|
linkerd.io/proxy-version: {{.Values.proxy.image.version | default .Values.linkerdVersion}}
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{/*
|
||||||
|
To add labels to the control-plane components, instead update at individual component manifests as
|
||||||
|
adding here would also update `spec.selector.matchLabels` which are immutable and would fail upgrades.
|
||||||
|
*/}}
|
||||||
|
{{- define "partials.proxy.labels" -}}
|
||||||
|
linkerd.io/proxy-{{.workloadKind}}: {{.component}}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,4 @@
|
||||||
|
{{- define "linkerd.node-selector" -}}
|
||||||
|
nodeSelector:
|
||||||
|
{{- toYaml .Values.nodeSelector | trim | nindent 2 }}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,18 @@
|
||||||
|
{{- define "partials.proxy.config.annotations" -}}
|
||||||
|
{{- with .cpu }}
|
||||||
|
{{- with .request -}}
|
||||||
|
config.linkerd.io/proxy-cpu-request: {{. | quote}}
|
||||||
|
{{end}}
|
||||||
|
{{- with .limit -}}
|
||||||
|
config.linkerd.io/proxy-cpu-limit: {{. | quote}}
|
||||||
|
{{- end}}
|
||||||
|
{{- end}}
|
||||||
|
{{- with .memory }}
|
||||||
|
{{- with .request }}
|
||||||
|
config.linkerd.io/proxy-memory-request: {{. | quote}}
|
||||||
|
{{end}}
|
||||||
|
{{- with .limit -}}
|
||||||
|
config.linkerd.io/proxy-memory-limit: {{. | quote}}
|
||||||
|
{{- end}}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,62 @@
|
||||||
|
{{- define "partials.proxy-init" -}}
|
||||||
|
args:
|
||||||
|
- --incoming-proxy-port
|
||||||
|
- {{.Values.proxy.ports.inbound | quote}}
|
||||||
|
- --outgoing-proxy-port
|
||||||
|
- {{.Values.proxy.ports.outbound | quote}}
|
||||||
|
- --proxy-uid
|
||||||
|
- {{.Values.proxy.uid | quote}}
|
||||||
|
- --inbound-ports-to-ignore
|
||||||
|
- "{{.Values.proxy.ports.control}},{{.Values.proxy.ports.admin}}{{ternary (printf ",%s" (.Values.proxyInit.ignoreInboundPorts | toString)) "" (not (empty .Values.proxyInit.ignoreInboundPorts)) }}"
|
||||||
|
{{- if .Values.proxyInit.ignoreOutboundPorts }}
|
||||||
|
- --outbound-ports-to-ignore
|
||||||
|
- {{.Values.proxyInit.ignoreOutboundPorts | quote}}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.proxyInit.closeWaitTimeoutSecs }}
|
||||||
|
- --timeout-close-wait-secs
|
||||||
|
- {{ .Values.proxyInit.closeWaitTimeoutSecs | quote}}
|
||||||
|
{{- end }}
|
||||||
|
image: {{.Values.proxyInit.image.name}}:{{.Values.proxyInit.image.version}}
|
||||||
|
imagePullPolicy: {{.Values.proxyInit.image.pullPolicy | default .Values.imagePullPolicy}}
|
||||||
|
name: linkerd-init
|
||||||
|
{{ include "partials.resources" .Values.proxyInit.resources }}
|
||||||
|
securityContext:
|
||||||
|
{{- if .Values.proxyInit.closeWaitTimeoutSecs }}
|
||||||
|
allowPrivilegeEscalation: true
|
||||||
|
{{- else }}
|
||||||
|
allowPrivilegeEscalation: false
|
||||||
|
{{- end }}
|
||||||
|
capabilities:
|
||||||
|
add:
|
||||||
|
- NET_ADMIN
|
||||||
|
- NET_RAW
|
||||||
|
{{- if .Values.proxyInit.capabilities -}}
|
||||||
|
{{- if .Values.proxyInit.capabilities.add }}
|
||||||
|
{{- toYaml .Values.proxyInit.capabilities.add | trim | nindent 4 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.proxyInit.capabilities.drop -}}
|
||||||
|
{{- include "partials.proxy-init.capabilities.drop" . | nindent 4 -}}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.proxyInit.closeWaitTimeoutSecs }}
|
||||||
|
privileged: true
|
||||||
|
{{- else }}
|
||||||
|
privileged: false
|
||||||
|
{{- end }}
|
||||||
|
readOnlyRootFilesystem: true
|
||||||
|
runAsNonRoot: false
|
||||||
|
runAsUser: 0
|
||||||
|
terminationMessagePolicy: FallbackToLogsOnError
|
||||||
|
{{- if or (not .Values.cniEnabled) .Values.proxyInit.saMountPath }}
|
||||||
|
volumeMounts:
|
||||||
|
{{- end -}}
|
||||||
|
{{- if not .Values.cniEnabled }}
|
||||||
|
- mountPath: {{.Values.proxyInit.xtMountPath.mountPath}}
|
||||||
|
name: {{.Values.proxyInit.xtMountPath.name}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.proxyInit.saMountPath }}
|
||||||
|
- mountPath: {{.Values.proxyInit.saMountPath.mountPath}}
|
||||||
|
name: {{.Values.proxyInit.saMountPath.name}}
|
||||||
|
readOnly: {{.Values.proxyInit.saMountPath.readOnly}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,189 @@
|
||||||
|
{{ define "partials.proxy" -}}
|
||||||
|
{{- $trustDomain := (.Values.identityTrustDomain | default .Values.clusterDomain) -}}
|
||||||
|
env:
|
||||||
|
- name: _pod_name
|
||||||
|
valueFrom:
|
||||||
|
fieldRef:
|
||||||
|
fieldPath: metadata.name
|
||||||
|
- name: _pod_ns
|
||||||
|
valueFrom:
|
||||||
|
fieldRef:
|
||||||
|
fieldPath: metadata.namespace
|
||||||
|
- name: _pod_nodeName
|
||||||
|
valueFrom:
|
||||||
|
fieldRef:
|
||||||
|
fieldPath: spec.nodeName
|
||||||
|
{{- if .Values.proxy.cores }}
|
||||||
|
- name: LINKERD2_PROXY_CORES
|
||||||
|
value: {{.Values.proxy.cores | quote}}
|
||||||
|
{{- end }}
|
||||||
|
{{ if .Values.proxy.requireIdentityOnInboundPorts -}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_PORTS_REQUIRE_IDENTITY
|
||||||
|
value: {{.Values.proxy.requireIdentityOnInboundPorts | quote}}
|
||||||
|
{{ end -}}
|
||||||
|
{{ if .Values.proxy.requireTLSOnInboundPorts -}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_PORTS_REQUIRE_TLS
|
||||||
|
value: {{.Values.proxy.requireTLSOnInboundPorts | quote}}
|
||||||
|
{{ end -}}
|
||||||
|
- name: LINKERD2_PROXY_LOG
|
||||||
|
value: {{.Values.proxy.logLevel | quote}}
|
||||||
|
- name: LINKERD2_PROXY_LOG_FORMAT
|
||||||
|
value: {{.Values.proxy.logFormat | quote}}
|
||||||
|
- name: LINKERD2_PROXY_DESTINATION_SVC_ADDR
|
||||||
|
value: {{ternary "localhost.:8086" (printf "linkerd-dst-headless.%s.svc.%s.:8086" .Values.namespace .Values.clusterDomain) (eq (toString .Values.proxy.component) "linkerd-destination")}}
|
||||||
|
- name: LINKERD2_PROXY_DESTINATION_PROFILE_NETWORKS
|
||||||
|
value: {{.Values.clusterNetworks | quote}}
|
||||||
|
- name: LINKERD2_PROXY_POLICY_SVC_ADDR
|
||||||
|
value: {{ternary "localhost.:8090" (printf "linkerd-policy.%s.svc.%s.:8090" .Values.namespace .Values.clusterDomain) (eq (toString .Values.proxy.component) "linkerd-destination")}}
|
||||||
|
- name: LINKERD2_PROXY_POLICY_WORKLOAD
|
||||||
|
value: "$(_pod_ns):$(_pod_name)"
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_DEFAULT_POLICY
|
||||||
|
value: {{.Values.proxy.defaultInboundPolicy | default .Values.policyController.defaultAllowPolicy}}
|
||||||
|
- name: LINKERD2_PROXY_POLICY_CLUSTER_NETWORKS
|
||||||
|
value: {{.Values.clusterNetworks | quote}}
|
||||||
|
{{ if .Values.proxy.inboundConnectTimeout -}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_CONNECT_TIMEOUT
|
||||||
|
value: {{.Values.proxy.inboundConnectTimeout | quote}}
|
||||||
|
{{ end -}}
|
||||||
|
{{ if .Values.proxy.outboundConnectTimeout -}}
|
||||||
|
- name: LINKERD2_PROXY_OUTBOUND_CONNECT_TIMEOUT
|
||||||
|
value: {{.Values.proxy.outboundConnectTimeout | quote}}
|
||||||
|
{{ end -}}
|
||||||
|
- name: LINKERD2_PROXY_CONTROL_LISTEN_ADDR
|
||||||
|
value: 0.0.0.0:{{.Values.proxy.ports.control}}
|
||||||
|
- name: LINKERD2_PROXY_ADMIN_LISTEN_ADDR
|
||||||
|
value: 0.0.0.0:{{.Values.proxy.ports.admin}}
|
||||||
|
- name: LINKERD2_PROXY_OUTBOUND_LISTEN_ADDR
|
||||||
|
value: 127.0.0.1:{{.Values.proxy.ports.outbound}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_LISTEN_ADDR
|
||||||
|
value: 0.0.0.0:{{.Values.proxy.ports.inbound}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_IPS
|
||||||
|
valueFrom:
|
||||||
|
fieldRef:
|
||||||
|
fieldPath: status.podIPs
|
||||||
|
{{ if .Values.proxy.podInboundPorts -}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_PORTS
|
||||||
|
value: {{ .Values.proxy.podInboundPorts | quote }}
|
||||||
|
{{ end -}}
|
||||||
|
{{ if .Values.proxy.isGateway -}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_GATEWAY_SUFFIXES
|
||||||
|
value: {{printf "svc.%s." .Values.clusterDomain}}
|
||||||
|
{{ end -}}
|
||||||
|
{{ if .Values.proxy.isIngress -}}
|
||||||
|
- name: LINKERD2_PROXY_INGRESS_MODE
|
||||||
|
value: "true"
|
||||||
|
{{ end -}}
|
||||||
|
- name: LINKERD2_PROXY_DESTINATION_PROFILE_SUFFIXES
|
||||||
|
{{- $internalDomain := printf "svc.%s." .Values.clusterDomain }}
|
||||||
|
value: {{ternary "." $internalDomain .Values.proxy.enableExternalProfiles}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_ACCEPT_KEEPALIVE
|
||||||
|
value: 10000ms
|
||||||
|
- name: LINKERD2_PROXY_OUTBOUND_CONNECT_KEEPALIVE
|
||||||
|
value: 10000ms
|
||||||
|
{{ if .Values.proxy.opaquePorts -}}
|
||||||
|
- name: LINKERD2_PROXY_INBOUND_PORTS_DISABLE_PROTOCOL_DETECTION
|
||||||
|
value: {{.Values.proxy.opaquePorts | quote}}
|
||||||
|
{{ end -}}
|
||||||
|
- name: LINKERD2_PROXY_DESTINATION_CONTEXT
|
||||||
|
value: |
|
||||||
|
{"ns":"$(_pod_ns)", "nodeName":"$(_pod_nodeName)"}
|
||||||
|
{{ if .Values.proxy.disableIdentity -}}
|
||||||
|
- name: LINKERD2_PROXY_IDENTITY_DISABLED
|
||||||
|
value: disabled
|
||||||
|
{{ else -}}
|
||||||
|
- name: _pod_sa
|
||||||
|
valueFrom:
|
||||||
|
fieldRef:
|
||||||
|
fieldPath: spec.serviceAccountName
|
||||||
|
- name: _l5d_ns
|
||||||
|
value: {{.Values.namespace}}
|
||||||
|
- name: _l5d_trustdomain
|
||||||
|
value: {{$trustDomain}}
|
||||||
|
- name: LINKERD2_PROXY_IDENTITY_DIR
|
||||||
|
value: /var/run/linkerd/identity/end-entity
|
||||||
|
- name: LINKERD2_PROXY_IDENTITY_TRUST_ANCHORS
|
||||||
|
{{- /*
|
||||||
|
Pods in the `linkerd` namespace are not injected by the proxy injector and instead obtain
|
||||||
|
the trust anchor bundle from the `linkerd-identity-trust-roots` configmap. This should not
|
||||||
|
be used in other contexts.
|
||||||
|
*/}}
|
||||||
|
{{- if .Values.proxy.loadTrustBundleFromConfigMap }}
|
||||||
|
valueFrom:
|
||||||
|
configMapKeyRef:
|
||||||
|
name: linkerd-identity-trust-roots
|
||||||
|
key: ca-bundle.crt
|
||||||
|
{{ else }}
|
||||||
|
value: |
|
||||||
|
{{- required "Please provide the identity trust anchors" .Values.identityTrustAnchorsPEM | trim | nindent 4 }}
|
||||||
|
{{ end -}}
|
||||||
|
- name: LINKERD2_PROXY_IDENTITY_TOKEN_FILE
|
||||||
|
value: /var/run/secrets/kubernetes.io/serviceaccount/token
|
||||||
|
- name: LINKERD2_PROXY_IDENTITY_SVC_ADDR
|
||||||
|
value: {{ternary "localhost.:8080" (printf "linkerd-identity-headless.%s.svc.%s.:8080" .Values.namespace .Values.clusterDomain) (eq (toString .Values.proxy.component) "linkerd-identity")}}
|
||||||
|
- name: LINKERD2_PROXY_IDENTITY_LOCAL_NAME
|
||||||
|
value: $(_pod_sa).$(_pod_ns).serviceaccount.identity.{{.Values.namespace}}.{{$trustDomain}}
|
||||||
|
- name: LINKERD2_PROXY_IDENTITY_SVC_NAME
|
||||||
|
value: linkerd-identity.{{.Values.namespace}}.serviceaccount.identity.{{.Values.namespace}}.{{$trustDomain}}
|
||||||
|
- name: LINKERD2_PROXY_DESTINATION_SVC_NAME
|
||||||
|
value: linkerd-destination.{{.Values.namespace}}.serviceaccount.identity.{{.Values.namespace}}.{{$trustDomain}}
|
||||||
|
- name: LINKERD2_PROXY_POLICY_SVC_NAME
|
||||||
|
value: linkerd-destination.{{.Values.namespace}}.serviceaccount.identity.{{.Values.namespace}}.{{$trustDomain}}
|
||||||
|
{{ end -}}
|
||||||
|
image: {{.Values.proxy.image.name}}:{{.Values.proxy.image.version | default .Values.linkerdVersion}}
|
||||||
|
imagePullPolicy: {{.Values.proxy.image.pullPolicy | default .Values.imagePullPolicy}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /live
|
||||||
|
port: {{.Values.proxy.ports.admin}}
|
||||||
|
initialDelaySeconds: 10
|
||||||
|
name: linkerd-proxy
|
||||||
|
ports:
|
||||||
|
- containerPort: {{.Values.proxy.ports.inbound}}
|
||||||
|
name: linkerd-proxy
|
||||||
|
- containerPort: {{.Values.proxy.ports.admin}}
|
||||||
|
name: linkerd-admin
|
||||||
|
readinessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /ready
|
||||||
|
port: {{.Values.proxy.ports.admin}}
|
||||||
|
initialDelaySeconds: 2
|
||||||
|
{{- if .Values.proxy.resources }}
|
||||||
|
{{ include "partials.resources" .Values.proxy.resources }}
|
||||||
|
{{- end }}
|
||||||
|
securityContext:
|
||||||
|
allowPrivilegeEscalation: false
|
||||||
|
{{- if .Values.proxy.capabilities -}}
|
||||||
|
{{- include "partials.proxy.capabilities" . | nindent 2 -}}
|
||||||
|
{{- end }}
|
||||||
|
readOnlyRootFilesystem: true
|
||||||
|
runAsUser: {{.Values.proxy.uid}}
|
||||||
|
terminationMessagePolicy: FallbackToLogsOnError
|
||||||
|
{{- if or (.Values.proxy.await) (.Values.proxy.waitBeforeExitSeconds) }}
|
||||||
|
lifecycle:
|
||||||
|
{{- if .Values.proxy.await }}
|
||||||
|
postStart:
|
||||||
|
exec:
|
||||||
|
command:
|
||||||
|
- /usr/lib/linkerd/linkerd-await
|
||||||
|
{{- end }}
|
||||||
|
{{- if .Values.proxy.waitBeforeExitSeconds }}
|
||||||
|
preStop:
|
||||||
|
exec:
|
||||||
|
command:
|
||||||
|
- /bin/sleep
|
||||||
|
- {{.Values.proxy.waitBeforeExitSeconds | quote}}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if or (not .Values.proxy.disableIdentity) (.Values.proxy.saMountPath) }}
|
||||||
|
volumeMounts:
|
||||||
|
{{- if not .Values.proxy.disableIdentity }}
|
||||||
|
- mountPath: /var/run/linkerd/identity/end-entity
|
||||||
|
name: linkerd-identity-end-entity
|
||||||
|
{{- end -}}
|
||||||
|
{{- if .Values.proxy.saMountPath }}
|
||||||
|
- mountPath: {{.Values.proxy.saMountPath.mountPath}}
|
||||||
|
name: {{.Values.proxy.saMountPath.name}}
|
||||||
|
readOnly: {{.Values.proxy.saMountPath.readOnly}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,6 @@
|
||||||
|
{{- define "partials.image-pull-secrets"}}
|
||||||
|
{{- if . }}
|
||||||
|
imagePullSecrets:
|
||||||
|
{{ toYaml . | indent 2 }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,21 @@
|
||||||
|
{{- define "partials.resources" -}}
|
||||||
|
resources:
|
||||||
|
{{- if or .cpu.limit .memory.limit }}
|
||||||
|
limits:
|
||||||
|
{{- with .cpu.limit }}
|
||||||
|
cpu: {{. | quote}}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .memory.limit }}
|
||||||
|
memory: {{. | quote}}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- if or .cpu.request .memory.request }}
|
||||||
|
requests:
|
||||||
|
{{- with .cpu.request }}
|
||||||
|
cpu: {{. | quote}}
|
||||||
|
{{- end }}
|
||||||
|
{{- with .memory.request }}
|
||||||
|
memory: {{. | quote}}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,4 @@
|
||||||
|
{{- define "linkerd.tolerations" -}}
|
||||||
|
tolerations:
|
||||||
|
{{ toYaml .Values.tolerations | trim | indent 2 }}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,5 @@
|
||||||
|
{{ define "partials.linkerd.trace" -}}
|
||||||
|
{{ if .Values.controlPlaneTracing -}}
|
||||||
|
- -trace-collector=collector.{{.Values.controlPlaneTracingNamespace}}.svc.{{.Values.clusterDomain}}:55678
|
||||||
|
{{ end -}}
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,5 @@
|
||||||
|
{{- define "linkerd.proxy.validation" -}}
|
||||||
|
{{- if .disableIdentity -}}
|
||||||
|
{{- fail (printf "Can't disable identity mTLS for %s. Set '.Values.proxy.disableIdentity' to 'false'" .component) -}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,10 @@
|
||||||
|
{{ define "partials.proxy.volumes.identity" -}}
|
||||||
|
emptyDir:
|
||||||
|
medium: Memory
|
||||||
|
name: linkerd-identity-end-entity
|
||||||
|
{{- end -}}
|
||||||
|
|
||||||
|
{{ define "partials.proxyInit.volumes.xtables" -}}
|
||||||
|
emptyDir: {}
|
||||||
|
name: {{ .Values.proxyInit.xtMountPath.name }}
|
||||||
|
{{- end -}}
|
|
@ -0,0 +1,25 @@
|
||||||
|
questions:
|
||||||
|
- variable: identityTrustAnchorsPEM
|
||||||
|
label: "Trust root certificate (ECDSA)"
|
||||||
|
description: "Root certificate used to support mTLS connections between meshed pods"
|
||||||
|
required: true
|
||||||
|
type: multiline
|
||||||
|
group: Identity
|
||||||
|
- variable: identity.issuer.tls.crtPEM
|
||||||
|
label: "Issuer certificate (ECDSA)"
|
||||||
|
description: "Intermediate certificate, rooted on identityTrustAnchorsPEM, used to sign the Linkerd proxies' CSR"
|
||||||
|
required: true
|
||||||
|
type: multiline
|
||||||
|
group: Identity
|
||||||
|
- variable: identity.issuer.tls.keyPEM
|
||||||
|
label: "Key for the issuer certificate (ECDSA)"
|
||||||
|
description: "Private key for the certificate entered on crtPEM"
|
||||||
|
required: true
|
||||||
|
type: multiline
|
||||||
|
group: Identity
|
||||||
|
- variable: identity.issuer.crtExpiry
|
||||||
|
label: "Expiration timestamp for the issuer certificate"
|
||||||
|
description: "This must match the expiry date in crtPEM"
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
group: Identity
|
|
@ -0,0 +1,6 @@
|
||||||
|
dependencies:
|
||||||
|
- name: partials
|
||||||
|
repository: file://../partials
|
||||||
|
version: 0.1.0
|
||||||
|
digest: sha256:8e42f9c9d4a2dc883f17f94d6044c97518ced19ad0922f47b8760e47135369ba
|
||||||
|
generated: "2020-12-21T17:47:25.811707816Z"
|
|
@ -0,0 +1,4 @@
|
||||||
|
dependencies:
|
||||||
|
- name: partials
|
||||||
|
version: 0.1.0
|
||||||
|
repository: file://../partials
|
|
@ -0,0 +1,19 @@
|
||||||
|
The Linkerd control plane was successfully installed 🎉
|
||||||
|
|
||||||
|
To help you manage your Linkerd service mesh you can install the Linkerd CLI by running:
|
||||||
|
|
||||||
|
curl -sL https://run.linkerd.io/install | sh
|
||||||
|
|
||||||
|
Alternatively, you can download the CLI directly via the Linkerd releases page:
|
||||||
|
|
||||||
|
https://github.com/linkerd/linkerd2/releases/
|
||||||
|
|
||||||
|
To make sure everything works as expected, run the following:
|
||||||
|
|
||||||
|
linkerd check
|
||||||
|
|
||||||
|
Linkerd Viz extension can be installed by running:
|
||||||
|
|
||||||
|
linkerd viz install | kubectl apply -f -
|
||||||
|
|
||||||
|
Looking for more? Visit https://linkerd.io/2/getting-started/
|
|
@ -0,0 +1,34 @@
|
||||||
|
---
|
||||||
|
kind: ConfigMap
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-config
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: controller
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
data:
|
||||||
|
values: |
|
||||||
|
{{- $values := deepCopy .Values }}
|
||||||
|
{{- /*
|
||||||
|
WARNING! All sensitive or private data such as TLS keys must be removed
|
||||||
|
here to avoid it being publicly readable.
|
||||||
|
*/ -}}
|
||||||
|
{{- if kindIs "map" $values.identity.issuer.tls -}}
|
||||||
|
{{- $_ := unset $values.identity.issuer.tls "keyPEM"}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if kindIs "map" $values.profileValidator -}}
|
||||||
|
{{- $_ := unset $values.profileValidator "keyPEM"}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if kindIs "map" $values.proxyInjector -}}
|
||||||
|
{{- $_ := unset $values.proxyInjector "keyPEM"}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- if (empty $values.identityTrustDomain) -}}
|
||||||
|
{{- $_ := set $values "identityTrustDomain" $values.clusterDomain}}
|
||||||
|
{{- end -}}
|
||||||
|
{{- $_ := unset $values "partials"}}
|
||||||
|
{{- $_ := unset $values "configs"}}
|
||||||
|
{{- $_ := unset $values "stage"}}
|
||||||
|
{{- toYaml $values | trim | nindent 4 }}
|
|
@ -0,0 +1,198 @@
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Destination Controller Service
|
||||||
|
###
|
||||||
|
kind: ClusterRole
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-{{.Values.namespace}}-destination
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
rules:
|
||||||
|
- apiGroups: ["apps"]
|
||||||
|
resources: ["replicasets"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
- apiGroups: ["batch"]
|
||||||
|
resources: ["jobs"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["pods", "endpoints", "services", "nodes", "namespaces"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
- apiGroups: ["linkerd.io"]
|
||||||
|
resources: ["serviceprofiles"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
- apiGroups: ["split.smi-spec.io"]
|
||||||
|
resources: ["trafficsplits"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
{{- if .Values.enableEndpointSlices }}
|
||||||
|
- apiGroups: ["discovery.k8s.io"]
|
||||||
|
resources: ["endpointslices"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
{{- end }}
|
||||||
|
---
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-{{.Values.namespace}}-destination
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: linkerd-{{.Values.namespace}}-destination
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-destination
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
---
|
||||||
|
kind: ServiceAccount
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-destination
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.image-pull-secrets" .Values.imagePullSecrets }}
|
||||||
|
---
|
||||||
|
{{- $host := printf "linkerd-sp-validator.%s.svc" .Values.namespace }}
|
||||||
|
{{- $ca := genSelfSignedCert $host (list) (list $host) 365 }}
|
||||||
|
{{- if (not .Values.profileValidator.externalSecret) }}
|
||||||
|
kind: Secret
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-sp-validator-k8s-tls
|
||||||
|
namespace: {{ .Values.namespace }}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
type: kubernetes.io/tls
|
||||||
|
data:
|
||||||
|
tls.crt: {{ ternary (b64enc (trim $ca.Cert)) (b64enc (trim .Values.profileValidator.crtPEM)) (empty .Values.profileValidator.crtPEM) }}
|
||||||
|
tls.key: {{ ternary (b64enc (trim $ca.Key)) (b64enc (trim .Values.profileValidator.keyPEM)) (empty .Values.profileValidator.keyPEM) }}
|
||||||
|
---
|
||||||
|
{{- end }}
|
||||||
|
apiVersion: admissionregistration.k8s.io/v1
|
||||||
|
kind: ValidatingWebhookConfiguration
|
||||||
|
metadata:
|
||||||
|
name: linkerd-sp-validator-webhook-config
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
webhooks:
|
||||||
|
- name: linkerd-sp-validator.linkerd.io
|
||||||
|
namespaceSelector:
|
||||||
|
{{- toYaml .Values.profileValidator.namespaceSelector | trim | nindent 4 }}
|
||||||
|
clientConfig:
|
||||||
|
service:
|
||||||
|
name: linkerd-sp-validator
|
||||||
|
namespace: {{ .Values.namespace }}
|
||||||
|
path: "/"
|
||||||
|
{{- if and (.Values.profileValidator.externalSecret) (empty .Values.profileValidator.caBundle) }}
|
||||||
|
{{- fail "If profileValidator.externalSecret is true then you need to provide profileValidator.caBundle" }}
|
||||||
|
{{- end }}
|
||||||
|
caBundle: {{ ternary (b64enc (trim $ca.Cert)) (b64enc (trim .Values.profileValidator.caBundle)) (empty .Values.profileValidator.caBundle) }}
|
||||||
|
failurePolicy: {{.Values.webhookFailurePolicy}}
|
||||||
|
admissionReviewVersions: ["v1", "v1beta1"]
|
||||||
|
rules:
|
||||||
|
- operations: ["CREATE", "UPDATE"]
|
||||||
|
apiGroups: ["linkerd.io"]
|
||||||
|
apiVersions: ["v1alpha1", "v1alpha2"]
|
||||||
|
resources: ["serviceprofiles"]
|
||||||
|
sideEffects: None
|
||||||
|
---
|
||||||
|
{{- $host := printf "linkerd-policy-validator.%s.svc" .Values.namespace }}
|
||||||
|
{{- $ca := genSelfSignedCert $host (list) (list $host) 365 }}
|
||||||
|
{{- if (not .Values.policyValidator.externalSecret) }}
|
||||||
|
kind: Secret
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-policy-validator-k8s-tls
|
||||||
|
namespace: {{ .Values.namespace }}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
type: kubernetes.io/tls
|
||||||
|
data:
|
||||||
|
tls.crt: {{ ternary (b64enc (trim $ca.Cert)) (b64enc (trim .Values.policyValidator.crtPEM)) (empty .Values.policyValidator.crtPEM) }}
|
||||||
|
tls.key: {{ ternary (b64enc (trim $ca.Key)) (b64enc (trim .Values.policyValidator.keyPEM)) (empty .Values.policyValidator.keyPEM) }}
|
||||||
|
---
|
||||||
|
{{- end }}
|
||||||
|
apiVersion: admissionregistration.k8s.io/v1
|
||||||
|
kind: ValidatingWebhookConfiguration
|
||||||
|
metadata:
|
||||||
|
name: linkerd-policy-validator-webhook-config
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
webhooks:
|
||||||
|
- name: linkerd-policy-validator.linkerd.io
|
||||||
|
namespaceSelector:
|
||||||
|
{{- toYaml .Values.policyValidator.namespaceSelector | trim | nindent 4 }}
|
||||||
|
clientConfig:
|
||||||
|
service:
|
||||||
|
name: linkerd-policy-validator
|
||||||
|
namespace: {{ .Values.namespace }}
|
||||||
|
path: "/"
|
||||||
|
{{- if and (.Values.policyValidator.externalSecret) (empty .Values.policyValidator.caBundle) }}
|
||||||
|
{{- fail "If policyValidator.externalSecret is true then you need to provide policyValidator.caBundle" }}
|
||||||
|
{{- end }}
|
||||||
|
caBundle: {{ ternary (b64enc (trim $ca.Cert)) (b64enc (trim .Values.policyValidator.caBundle)) (empty .Values.policyValidator.caBundle) }}
|
||||||
|
failurePolicy: {{.Values.webhookFailurePolicy}}
|
||||||
|
admissionReviewVersions: ["v1", "v1beta1"]
|
||||||
|
rules:
|
||||||
|
- operations: ["CREATE", "UPDATE"]
|
||||||
|
apiGroups: ["policy.linkerd.io"]
|
||||||
|
apiVersions: ["v1alpha1", "v1beta1"]
|
||||||
|
resources: ["servers"]
|
||||||
|
sideEffects: None
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRole
|
||||||
|
metadata:
|
||||||
|
name: linkerd-policy
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/part-of: Linkerd
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
rules:
|
||||||
|
- apiGroups:
|
||||||
|
- ""
|
||||||
|
resources:
|
||||||
|
- pods
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
- apiGroups:
|
||||||
|
- policy.linkerd.io
|
||||||
|
resources:
|
||||||
|
- servers
|
||||||
|
- serverauthorizations
|
||||||
|
verbs:
|
||||||
|
- get
|
||||||
|
- list
|
||||||
|
- watch
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: linkerd-destination-policy
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/part-of: Linkerd
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: linkerd-policy
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-destination
|
||||||
|
namespace: {{.Values.namespace}}
|
|
@ -0,0 +1,311 @@
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Destination Controller Service
|
||||||
|
###
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-dst
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
type: ClusterIP
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
ports:
|
||||||
|
- name: grpc
|
||||||
|
port: 8086
|
||||||
|
targetPort: 8086
|
||||||
|
---
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-dst-headless
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
clusterIP: None
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
ports:
|
||||||
|
- name: grpc
|
||||||
|
port: 8086
|
||||||
|
targetPort: 8086
|
||||||
|
---
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-sp-validator
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
type: ClusterIP
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
ports:
|
||||||
|
- name: sp-validator
|
||||||
|
port: 443
|
||||||
|
targetPort: sp-validator
|
||||||
|
---
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-policy
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
clusterIP: None
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
ports:
|
||||||
|
- name: grpc
|
||||||
|
port: 8090
|
||||||
|
targetPort: 8090
|
||||||
|
---
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-policy-validator
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
type: ClusterIP
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
ports:
|
||||||
|
- name: policy-https
|
||||||
|
port: 443
|
||||||
|
targetPort: policy-https
|
||||||
|
{{- if .Values.enablePodAntiAffinity }}
|
||||||
|
---
|
||||||
|
kind: PodDisruptionBudget
|
||||||
|
apiVersion: policy/v1beta1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-dst
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
maxUnavailable: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
{{- end }}
|
||||||
|
---
|
||||||
|
{{- $tree := deepCopy . }}
|
||||||
|
{{ $_ := set $tree.Values.proxy "workloadKind" "deployment" -}}
|
||||||
|
{{ $_ := set $tree.Values.proxy "component" "linkerd-destination" -}}
|
||||||
|
{{ include "linkerd.proxy.validation" .Values.proxy -}}
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: destination
|
||||||
|
app.kubernetes.io/part-of: Linkerd
|
||||||
|
app.kubernetes.io/version: {{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
name: linkerd-destination
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
replicas: {{.Values.controllerReplicas}}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.proxy.labels" $tree.Values.proxy | nindent 6}}
|
||||||
|
{{- if .Values.enablePodAntiAffinity }}
|
||||||
|
strategy:
|
||||||
|
rollingUpdate:
|
||||||
|
maxUnavailable: 1
|
||||||
|
{{- end }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
{{- if (or (empty .Values.cliVersion) (not (eq (.Values.stage | toString) "control-plane"))) }}
|
||||||
|
checksum/config: {{ include (print $.Template.BasePath "/destination-rbac.yaml") . | sha256sum }}
|
||||||
|
{{- end }}
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
{{- include "partials.proxy.annotations" . | nindent 8}}
|
||||||
|
{{- with .Values.podAnnotations }}{{ toYaml . | trim | nindent 8 }}{{- end }}
|
||||||
|
config.linkerd.io/default-inbound-policy: "all-unauthenticated"
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: destination
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
linkerd.io/workload-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.proxy.labels" $tree.Values.proxy | nindent 8}}
|
||||||
|
{{- with .Values.podLabels }}{{ toYaml . | trim | nindent 8 }}{{- end }}
|
||||||
|
spec:
|
||||||
|
{{- if .Values.tolerations -}}
|
||||||
|
{{- include "linkerd.tolerations" . | nindent 6 }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- include "linkerd.node-selector" . | nindent 6 }}
|
||||||
|
{{- if .Values.enablePodAntiAffinity -}}
|
||||||
|
{{- $local := dict "component" "destination" -}}
|
||||||
|
{{- include "linkerd.pod-affinity" $local | nindent 6 -}}
|
||||||
|
{{- end }}
|
||||||
|
containers:
|
||||||
|
{{- if not (empty .Values.destinationProxyResources) }}
|
||||||
|
{{- $r := merge .Values.destinationProxyResources .Values.proxy.resources }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "resources" $r }}
|
||||||
|
{{- end }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "await" true }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "loadTrustBundleFromConfigMap" true }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "podInboundPorts" "8086,8090,8443,9443,9990,9996,9997" }}
|
||||||
|
{{- /*
|
||||||
|
The pod needs to accept webhook traffic, and we can't rely on that originating in the
|
||||||
|
cluster network.
|
||||||
|
*/}}
|
||||||
|
{{- $_ := set $tree.Values.proxy "defaultInboundPolicy" "all-unauthenticated" }}
|
||||||
|
- {{- include "partials.proxy" $tree | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
- args:
|
||||||
|
- destination
|
||||||
|
- -addr=:8086
|
||||||
|
- -controller-namespace={{.Values.namespace}}
|
||||||
|
- -enable-h2-upgrade={{.Values.enableH2Upgrade}}
|
||||||
|
- -log-level={{.Values.controllerLogLevel}}
|
||||||
|
- -log-format={{.Values.controllerLogFormat}}
|
||||||
|
- -enable-endpoint-slices={{.Values.enableEndpointSlices}}
|
||||||
|
- -cluster-domain={{.Values.clusterDomain}}
|
||||||
|
- -identity-trust-domain={{.Values.identityTrustDomain | default .Values.clusterDomain}}
|
||||||
|
- -default-opaque-ports={{.Values.proxy.opaquePorts}}
|
||||||
|
{{- include "partials.linkerd.trace" . | nindent 8 -}}
|
||||||
|
image: {{.Values.controllerImage}}:{{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
imagePullPolicy: {{.Values.imagePullPolicy}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /ping
|
||||||
|
port: 9996
|
||||||
|
initialDelaySeconds: 10
|
||||||
|
name: destination
|
||||||
|
ports:
|
||||||
|
- containerPort: 8086
|
||||||
|
name: grpc
|
||||||
|
- containerPort: 9996
|
||||||
|
name: admin-http
|
||||||
|
readinessProbe:
|
||||||
|
failureThreshold: 7
|
||||||
|
httpGet:
|
||||||
|
path: /ready
|
||||||
|
port: 9996
|
||||||
|
{{- if .Values.destinationResources -}}
|
||||||
|
{{- include "partials.resources" .Values.destinationResources | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
securityContext:
|
||||||
|
runAsUser: {{.Values.controllerUID}}
|
||||||
|
- args:
|
||||||
|
- sp-validator
|
||||||
|
- -log-level={{.Values.controllerLogLevel}}
|
||||||
|
- -log-format={{.Values.controllerLogFormat}}
|
||||||
|
image: {{.Values.controllerImage}}:{{.Values.controllerImageVersion | default .Values.linkerdVersion}}
|
||||||
|
imagePullPolicy: {{.Values.imagePullPolicy}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /ping
|
||||||
|
port: 9997
|
||||||
|
initialDelaySeconds: 10
|
||||||
|
name: sp-validator
|
||||||
|
ports:
|
||||||
|
- containerPort: 8443
|
||||||
|
name: sp-validator
|
||||||
|
- containerPort: 9997
|
||||||
|
name: admin-http
|
||||||
|
readinessProbe:
|
||||||
|
failureThreshold: 7
|
||||||
|
httpGet:
|
||||||
|
path: /ready
|
||||||
|
port: 9997
|
||||||
|
{{- if .Values.spValidatorResources -}}
|
||||||
|
{{- include "partials.resources" .Values.spValidatorResources | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
securityContext:
|
||||||
|
runAsUser: {{.Values.controllerUID}}
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: /var/run/linkerd/tls
|
||||||
|
name: sp-tls
|
||||||
|
readOnly: true
|
||||||
|
- args:
|
||||||
|
- --admin-addr=0.0.0.0:9990
|
||||||
|
- --grpc-addr=0.0.0.0:8090
|
||||||
|
- --admission-addr=0.0.0.0:9443
|
||||||
|
- --cluster-networks={{.Values.clusterNetworks}}
|
||||||
|
- --identity-domain={{.Values.identityTrustDomain | default .Values.clusterDomain}}
|
||||||
|
- --default-policy={{.Values.policyController.defaultAllowPolicy}}
|
||||||
|
- --log-level={{.Values.policyController.logLevel | default "linkerd=info,warn"}}
|
||||||
|
- --log-format={{.Values.controllerLogFormat}}
|
||||||
|
image: {{.Values.policyController.image.name}}:{{.Values.policyController.image.version | default .Values.linkerdVersion}}
|
||||||
|
imagePullPolicy: {{.Values.policyController.image.pullPolicy | default .Values.imagePullPolicy}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /ready
|
||||||
|
port: admin-http
|
||||||
|
initialDelaySeconds: 10
|
||||||
|
name: policy
|
||||||
|
ports:
|
||||||
|
- containerPort: 8090
|
||||||
|
name: grpc
|
||||||
|
- containerPort: 9990
|
||||||
|
name: admin-http
|
||||||
|
- containerPort: 9443
|
||||||
|
name: policy-https
|
||||||
|
readinessProbe:
|
||||||
|
failureThreshold: 7
|
||||||
|
httpGet:
|
||||||
|
path: /ready
|
||||||
|
port: admin-http
|
||||||
|
{{- $res := .Values.policyController.resources | default .Values.destinationResources }}
|
||||||
|
{{- if $res }}
|
||||||
|
{{- include "partials.resources" $res | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
securityContext:
|
||||||
|
runAsUser: {{.Values.controllerUID}}
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: /var/run/linkerd/tls
|
||||||
|
name: policy-tls
|
||||||
|
readOnly: true
|
||||||
|
{{ if not .Values.cniEnabled -}}
|
||||||
|
initContainers:
|
||||||
|
{{- /*
|
||||||
|
The destination controller needs to connect to the Kubernetes API before the proxy is able
|
||||||
|
to proxy requests, so we always skip these connections.
|
||||||
|
*/}}
|
||||||
|
{{- $_ := set $tree.Values.proxyInit "ignoreOutboundPorts" "443" }}
|
||||||
|
- {{- include "partials.proxy-init" $tree | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{ end -}}
|
||||||
|
serviceAccountName: linkerd-destination
|
||||||
|
volumes:
|
||||||
|
- name: sp-tls
|
||||||
|
secret:
|
||||||
|
secretName: linkerd-sp-validator-k8s-tls
|
||||||
|
- name: policy-tls
|
||||||
|
secret:
|
||||||
|
secretName: linkerd-policy-validator-k8s-tls
|
||||||
|
{{ if not .Values.cniEnabled -}}
|
||||||
|
- {{- include "partials.proxyInit.volumes.xtables" . | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{ end -}}
|
||||||
|
- {{- include "partials.proxy.volumes.identity" . | indent 8 | trimPrefix (repeat 7 " ") }}
|
|
@ -0,0 +1,73 @@
|
||||||
|
{{ if not .Values.disableHeartBeat -}}
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Heartbeat RBAC
|
||||||
|
###
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["configmaps"]
|
||||||
|
verbs: ["get"]
|
||||||
|
resourceNames: ["linkerd-config"]
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
roleRef:
|
||||||
|
kind: Role
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRole
|
||||||
|
metadata:
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["namespaces"]
|
||||||
|
verbs: ["list"]
|
||||||
|
- apiGroups: ["linkerd.io"]
|
||||||
|
resources: ["serviceprofiles"]
|
||||||
|
verbs: ["list"]
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
metadata:
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
roleRef:
|
||||||
|
kind: ClusterRole
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
---
|
||||||
|
kind: ServiceAccount
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: heartbeat
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.image-pull-secrets" .Values.imagePullSecrets }}
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,63 @@
|
||||||
|
{{ if not .Values.disableHeartBeat -}}
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Heartbeat
|
||||||
|
###
|
||||||
|
apiVersion: batch/v1beta1
|
||||||
|
kind: CronJob
|
||||||
|
metadata:
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: heartbeat
|
||||||
|
app.kubernetes.io/part-of: Linkerd
|
||||||
|
app.kubernetes.io/version: {{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
linkerd.io/control-plane-component: heartbeat
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
concurrencyPolicy: Replace
|
||||||
|
{{ if .Values.heartbeatSchedule -}}
|
||||||
|
schedule: "{{.Values.heartbeatSchedule}}"
|
||||||
|
{{ else -}}
|
||||||
|
schedule: "{{ dateInZone "04 15 * * *" (now | mustDateModify "+10m") "UTC"}}"
|
||||||
|
{{ end -}}
|
||||||
|
successfulJobsHistoryLimit: 0
|
||||||
|
jobTemplate:
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: heartbeat
|
||||||
|
linkerd.io/workload-ns: {{.Values.namespace}}
|
||||||
|
{{- with .Values.podLabels }}{{ toYaml . | trim | nindent 12 }}{{- end }}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
{{- with .Values.podAnnotations }}{{ toYaml . | trim | nindent 12 }}{{- end }}
|
||||||
|
spec:
|
||||||
|
{{- if .Values.tolerations -}}
|
||||||
|
{{- include "linkerd.tolerations" . | nindent 10 }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- include "linkerd.node-selector" . | nindent 10 }}
|
||||||
|
serviceAccountName: linkerd-heartbeat
|
||||||
|
restartPolicy: Never
|
||||||
|
containers:
|
||||||
|
- name: heartbeat
|
||||||
|
image: {{.Values.controllerImage}}:{{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
imagePullPolicy: {{.Values.imagePullPolicy}}
|
||||||
|
env:
|
||||||
|
- name: LINKERD_DISABLED
|
||||||
|
value: "the heartbeat controller does not use the proxy"
|
||||||
|
args:
|
||||||
|
- "heartbeat"
|
||||||
|
- "-controller-namespace={{.Values.namespace}}"
|
||||||
|
- "-log-level={{.Values.controllerLogLevel}}"
|
||||||
|
- "-log-format={{.Values.controllerLogFormat}}"
|
||||||
|
- "-prometheus-url=http://prometheus.linkerd-viz.svc.{{.Values.clusterDomain}}:9090"
|
||||||
|
{{- if .Values.heartbeatResources -}}
|
||||||
|
{{- include "partials.resources" .Values.heartbeatResources | nindent 12 }}
|
||||||
|
{{- end }}
|
||||||
|
securityContext:
|
||||||
|
runAsUser: {{.Values.controllerUID}}
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,49 @@
|
||||||
|
{{if .Values.identity -}}
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Identity Controller Service RBAC
|
||||||
|
###
|
||||||
|
kind: ClusterRole
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-{{.Values.namespace}}-identity
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
rules:
|
||||||
|
- apiGroups: ["authentication.k8s.io"]
|
||||||
|
resources: ["tokenreviews"]
|
||||||
|
verbs: ["create"]
|
||||||
|
- apiGroups: ["apps"]
|
||||||
|
resources: ["deployments"]
|
||||||
|
verbs: ["get"]
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["events"]
|
||||||
|
verbs: ["create", "patch"]
|
||||||
|
---
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-{{.Values.namespace}}-identity
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
roleRef:
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
kind: ClusterRole
|
||||||
|
name: linkerd-{{.Values.namespace}}-identity
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-identity
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
---
|
||||||
|
kind: ServiceAccount
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-identity
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.image-pull-secrets" .Values.imagePullSecrets }}
|
||||||
|
{{ end -}}
|
|
@ -0,0 +1,224 @@
|
||||||
|
{{if .Values.identity -}}
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Identity Controller Service
|
||||||
|
###
|
||||||
|
{{ if and (.Values.identity.issuer) (eq .Values.identity.issuer.scheme "linkerd.io/tls") -}}
|
||||||
|
---
|
||||||
|
kind: Secret
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-identity-issuer
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
linkerd.io/identity-issuer-expiry: {{required "Please provide the identity issuer certificate expiry date" .Values.identity.issuer.crtExpiry}}
|
||||||
|
data:
|
||||||
|
crt.pem: {{b64enc (required "Please provide the identity issuer certificate" .Values.identity.issuer.tls.crtPEM | trim)}}
|
||||||
|
key.pem: {{b64enc (required "Please provide the identity issue private key" .Values.identity.issuer.tls.keyPEM | trim)}}
|
||||||
|
{{- end}}
|
||||||
|
{{ if not (.Values.identity.externalCA) -}}
|
||||||
|
---
|
||||||
|
kind: ConfigMap
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-identity-trust-roots
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
data:
|
||||||
|
ca-bundle.crt: |{{.Values.identityTrustAnchorsPEM | trim | nindent 4}}
|
||||||
|
{{- end}}
|
||||||
|
---
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-identity
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
type: ClusterIP
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
ports:
|
||||||
|
- name: grpc
|
||||||
|
port: 8080
|
||||||
|
targetPort: 8080
|
||||||
|
---
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-identity-headless
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
clusterIP: None
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
ports:
|
||||||
|
- name: grpc
|
||||||
|
port: 8080
|
||||||
|
targetPort: 8080
|
||||||
|
{{- if .Values.enablePodAntiAffinity }}
|
||||||
|
---
|
||||||
|
kind: PodDisruptionBudget
|
||||||
|
apiVersion: policy/v1beta1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-identity
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
maxUnavailable: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
{{- end }}
|
||||||
|
---
|
||||||
|
{{- $tree := deepCopy . }}
|
||||||
|
{{ $_ := set $tree.Values.proxy "workloadKind" "deployment" -}}
|
||||||
|
{{ $_ := set $tree.Values.proxy "component" "linkerd-identity" -}}
|
||||||
|
{{ include "linkerd.proxy.validation" .Values.proxy -}}
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: identity
|
||||||
|
app.kubernetes.io/part-of: Linkerd
|
||||||
|
app.kubernetes.io/version: {{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
name: linkerd-identity
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
replicas: {{.Values.controllerReplicas}}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.proxy.labels" $tree.Values.proxy | nindent 6}}
|
||||||
|
{{- if .Values.enablePodAntiAffinity }}
|
||||||
|
strategy:
|
||||||
|
rollingUpdate:
|
||||||
|
maxUnavailable: 1
|
||||||
|
{{- end }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
{{- include "partials.proxy.annotations" . | nindent 8}}
|
||||||
|
{{- with .Values.podAnnotations }}{{ toYaml . | trim | nindent 8 }}{{- end }}
|
||||||
|
config.linkerd.io/default-inbound-policy: "all-unauthenticated"
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: identity
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
linkerd.io/workload-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.proxy.labels" $tree.Values.proxy | nindent 8}}
|
||||||
|
{{- with .Values.podLabels }}{{ toYaml . | trim | nindent 8 }}{{- end }}
|
||||||
|
spec:
|
||||||
|
{{- if .Values.tolerations -}}
|
||||||
|
{{- include "linkerd.tolerations" . | nindent 6 }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- include "linkerd.node-selector" . | nindent 6 }}
|
||||||
|
{{- if .Values.enablePodAntiAffinity -}}
|
||||||
|
{{- $local := dict "component" "identity" -}}
|
||||||
|
{{- include "linkerd.pod-affinity" $local | nindent 6 -}}
|
||||||
|
{{- end }}
|
||||||
|
containers:
|
||||||
|
- args:
|
||||||
|
- identity
|
||||||
|
- -log-level={{.Values.controllerLogLevel}}
|
||||||
|
- -log-format={{.Values.controllerLogFormat}}
|
||||||
|
- -controller-namespace={{.Values.namespace}}
|
||||||
|
- -identity-trust-domain={{.Values.identityTrustDomain | default .Values.clusterDomain}}
|
||||||
|
- -identity-issuance-lifetime={{.Values.identity.issuer.issuanceLifetime}}
|
||||||
|
- -identity-clock-skew-allowance={{.Values.identity.issuer.clockSkewAllowance}}
|
||||||
|
- -identity-scheme={{.Values.identity.issuer.scheme}}
|
||||||
|
{{- include "partials.linkerd.trace" . | nindent 8 -}}
|
||||||
|
env:
|
||||||
|
- name: LINKERD_DISABLED
|
||||||
|
value: "linkerd-await cannot block the identity controller"
|
||||||
|
image: {{.Values.controllerImage}}:{{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
imagePullPolicy: {{.Values.imagePullPolicy}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /ping
|
||||||
|
port: 9990
|
||||||
|
initialDelaySeconds: 10
|
||||||
|
name: identity
|
||||||
|
ports:
|
||||||
|
- containerPort: 8080
|
||||||
|
name: grpc
|
||||||
|
- containerPort: 9990
|
||||||
|
name: admin-http
|
||||||
|
readinessProbe:
|
||||||
|
failureThreshold: 7
|
||||||
|
httpGet:
|
||||||
|
path: /ready
|
||||||
|
port: 9990
|
||||||
|
{{- if .Values.identityResources -}}
|
||||||
|
{{- include "partials.resources" .Values.identityResources | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
securityContext:
|
||||||
|
runAsUser: {{.Values.controllerUID}}
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: /var/run/linkerd/identity/issuer
|
||||||
|
name: identity-issuer
|
||||||
|
- mountPath: /var/run/linkerd/identity/trust-roots/
|
||||||
|
name: trust-roots
|
||||||
|
{{- if not (empty .Values.identityProxyResources) }}
|
||||||
|
{{- $r := merge .Values.identityProxyResources .Values.proxy.resources }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "resources" $r }}
|
||||||
|
{{- end }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "await" false }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "loadTrustBundleFromConfigMap" true }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "podInboundPorts" "8080,9990" }}
|
||||||
|
{{- /*
|
||||||
|
The identity controller cannot discover policies, so we configure it with defaults that
|
||||||
|
enforce TLS on the identity service.
|
||||||
|
*/}}
|
||||||
|
{{- $_ := set $tree.Values.proxy "defaultInboundPolicy" "cluster-unauthenticated" }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "requireTLSOnInboundPorts" "8080" }}
|
||||||
|
- {{- include "partials.proxy" $tree | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{ if not .Values.cniEnabled -}}
|
||||||
|
initContainers:
|
||||||
|
{{- /*
|
||||||
|
The identity controller needs to connect to the Kubernetes API before the proxy is able to
|
||||||
|
proxy requests, so we always skip these connections. The identity controller makes no other
|
||||||
|
outbound connections (so it's not important to persist any other skip ports here)
|
||||||
|
*/}}
|
||||||
|
{{- $_ := set $tree.Values.proxyInit "ignoreOutboundPorts" "443" }}
|
||||||
|
- {{- include "partials.proxy-init" $tree | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{ end -}}
|
||||||
|
serviceAccountName: linkerd-identity
|
||||||
|
volumes:
|
||||||
|
- name: identity-issuer
|
||||||
|
secret:
|
||||||
|
secretName: linkerd-identity-issuer
|
||||||
|
- configMap:
|
||||||
|
name: linkerd-identity-trust-roots
|
||||||
|
name: trust-roots
|
||||||
|
{{ if not .Values.cniEnabled -}}
|
||||||
|
- {{- include "partials.proxyInit.volumes.xtables" . | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{ end -}}
|
||||||
|
- {{- include "partials.proxy.volumes.identity" . | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{end -}}
|
|
@ -0,0 +1,16 @@
|
||||||
|
{{- if (.Values.installNamespace) -}}
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Linkerd Namespace
|
||||||
|
###
|
||||||
|
kind: Namespace
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: {{ .Values.namespace }}
|
||||||
|
annotations:
|
||||||
|
linkerd.io/inject: disabled
|
||||||
|
labels:
|
||||||
|
linkerd.io/is-control-plane: "true"
|
||||||
|
config.linkerd.io/admission-webhooks: disabled
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
{{ end -}}
|
|
@ -0,0 +1,426 @@
|
||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
name: servers.policy.linkerd.io
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
group: policy.linkerd.io
|
||||||
|
names:
|
||||||
|
kind: Server
|
||||||
|
plural: servers
|
||||||
|
singular: server
|
||||||
|
shortNames: [srv]
|
||||||
|
scope: Namespaced
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
served: true
|
||||||
|
storage: false
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
required: [spec]
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- podSelector
|
||||||
|
- port
|
||||||
|
properties:
|
||||||
|
podSelector:
|
||||||
|
type: object
|
||||||
|
description: >-
|
||||||
|
Selects pods in the same namespace.
|
||||||
|
oneOf:
|
||||||
|
- required: [matchExpressions]
|
||||||
|
- required: [matchLabels]
|
||||||
|
properties:
|
||||||
|
matchLabels:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
matchExpressions:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [key, operator]
|
||||||
|
properties:
|
||||||
|
key:
|
||||||
|
type: string
|
||||||
|
operator:
|
||||||
|
type: string
|
||||||
|
enum: [In, NotIn, Exists, DoesNotExist]
|
||||||
|
values:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
description: >-
|
||||||
|
A port name or number. Must exist in a pod spec.
|
||||||
|
x-kubernetes-int-or-string: true
|
||||||
|
proxyProtocol:
|
||||||
|
description: >-
|
||||||
|
Configures protocol discovery for inbound connections.
|
||||||
|
|
||||||
|
Supersedes the `config.linkerd.io/opaque-ports` annotation.
|
||||||
|
type: string
|
||||||
|
default: unknown
|
||||||
|
enum:
|
||||||
|
- unknown
|
||||||
|
- HTTP/1
|
||||||
|
- HTTP/2
|
||||||
|
- gRPC
|
||||||
|
- opaque
|
||||||
|
- TLS
|
||||||
|
- name: v1beta1
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
required: [spec]
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- podSelector
|
||||||
|
- port
|
||||||
|
properties:
|
||||||
|
podSelector:
|
||||||
|
type: object
|
||||||
|
description: >-
|
||||||
|
Selects pods in the same namespace.
|
||||||
|
oneOf:
|
||||||
|
- required: [matchExpressions]
|
||||||
|
- required: [matchLabels]
|
||||||
|
properties:
|
||||||
|
matchLabels:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
matchExpressions:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [key, operator]
|
||||||
|
properties:
|
||||||
|
key:
|
||||||
|
type: string
|
||||||
|
operator:
|
||||||
|
type: string
|
||||||
|
enum: [In, NotIn, Exists, DoesNotExist]
|
||||||
|
values:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
port:
|
||||||
|
description: >-
|
||||||
|
A port name or number. Must exist in a pod spec.
|
||||||
|
x-kubernetes-int-or-string: true
|
||||||
|
proxyProtocol:
|
||||||
|
description: >-
|
||||||
|
Configures protocol discovery for inbound connections.
|
||||||
|
|
||||||
|
Supersedes the `config.linkerd.io/opaque-ports` annotation.
|
||||||
|
type: string
|
||||||
|
default: unknown
|
||||||
|
enum:
|
||||||
|
- unknown
|
||||||
|
- HTTP/1
|
||||||
|
- HTTP/2
|
||||||
|
- gRPC
|
||||||
|
- opaque
|
||||||
|
- TLS
|
||||||
|
additionalPrinterColumns:
|
||||||
|
- name: Port
|
||||||
|
type: string
|
||||||
|
description: The port the server is listening on
|
||||||
|
jsonPath: .spec.port
|
||||||
|
- name: Protocol
|
||||||
|
type: string
|
||||||
|
description: The protocol of the server
|
||||||
|
jsonPath: .spec.proxyProtocol
|
||||||
|
---
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
name: serverauthorizations.policy.linkerd.io
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
group: policy.linkerd.io
|
||||||
|
scope: Namespaced
|
||||||
|
names:
|
||||||
|
kind: ServerAuthorization
|
||||||
|
plural: serverauthorizations
|
||||||
|
singular: serverauthorization
|
||||||
|
shortNames: [saz]
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
served: true
|
||||||
|
storage: false
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
required: [spec]
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
description: >-
|
||||||
|
Authorizes clients to communicate with Linkerd-proxied servers.
|
||||||
|
type: object
|
||||||
|
required: [server, client]
|
||||||
|
properties:
|
||||||
|
server:
|
||||||
|
description: >-
|
||||||
|
Identifies servers in the same namespace for which this
|
||||||
|
authorization applies.
|
||||||
|
|
||||||
|
Only one of `name` or `selector` may be specified.
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [name]
|
||||||
|
- required: [selector]
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: References a `Server` instance by name
|
||||||
|
type: string
|
||||||
|
pattern: '^[a-z0-9]([-a-z0-9]*[a-z0-9])?$'
|
||||||
|
selector:
|
||||||
|
description: >-
|
||||||
|
A label query over servers on which this authorization applies.
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [matchLabels]
|
||||||
|
- required: [matchExpressions]
|
||||||
|
properties:
|
||||||
|
matchLabels:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
matchExpressions:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [key, operator]
|
||||||
|
properties:
|
||||||
|
key:
|
||||||
|
type: string
|
||||||
|
operator:
|
||||||
|
type: string
|
||||||
|
enum: [In, NotIn, Exists, DoesNotExist]
|
||||||
|
values:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
client:
|
||||||
|
description: Describes clients authorized to access a server.
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [meshTLS]
|
||||||
|
- required: [unauthenticated]
|
||||||
|
properties:
|
||||||
|
networks:
|
||||||
|
description: >-
|
||||||
|
Limits the client IP addresses to which this
|
||||||
|
authorization applies. If unset, the server chooses a
|
||||||
|
default (typically, all IPs or the cluster's pod
|
||||||
|
network).
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [cidr]
|
||||||
|
properties:
|
||||||
|
cidr:
|
||||||
|
type: string
|
||||||
|
except:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
unauthenticated:
|
||||||
|
description: >-
|
||||||
|
Authorizes unauthenticated clients to access a server.
|
||||||
|
type: boolean
|
||||||
|
meshTLS:
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [unauthenticatedTLS]
|
||||||
|
- required: [identities]
|
||||||
|
- required: [serviceAccounts]
|
||||||
|
properties:
|
||||||
|
unauthenticatedTLS:
|
||||||
|
type: boolean
|
||||||
|
description: >-
|
||||||
|
Indicates that no client identity is required for
|
||||||
|
communication.
|
||||||
|
|
||||||
|
This is mostly important for the identity
|
||||||
|
controller, which must terminate TLS connections
|
||||||
|
from clients that do not yet have a certificate.
|
||||||
|
identities:
|
||||||
|
description: >-
|
||||||
|
Authorizes clients with the provided proxy identity
|
||||||
|
strings (as provided via MTLS)
|
||||||
|
|
||||||
|
The `*` prefix can be used to match all identities in
|
||||||
|
a domain. An identity string of `*` indicates that
|
||||||
|
all authentication clients are authorized.
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
pattern: '^(\*|[a-z0-9]([-a-z0-9]*[a-z0-9])?)(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$'
|
||||||
|
serviceAccounts:
|
||||||
|
description: >-
|
||||||
|
Authorizes clients with the provided proxy identity
|
||||||
|
service accounts (as provided via MTLS)
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [name]
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: The ServiceAccount's name.
|
||||||
|
type: string
|
||||||
|
pattern: '^[a-z0-9]([-a-z0-9]*[a-z0-9])?$'
|
||||||
|
namespace:
|
||||||
|
description: >-
|
||||||
|
The ServiceAccount's namespace. If unset, the
|
||||||
|
authorization's namespace is used.
|
||||||
|
type: string
|
||||||
|
pattern: '^[a-z0-9]([-a-z0-9]*[a-z0-9])?$'
|
||||||
|
- name: v1beta1
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
required: [spec]
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
description: >-
|
||||||
|
Authorizes clients to communicate with Linkerd-proxied servers.
|
||||||
|
type: object
|
||||||
|
required: [server, client]
|
||||||
|
properties:
|
||||||
|
server:
|
||||||
|
description: >-
|
||||||
|
Identifies servers in the same namespace for which this
|
||||||
|
authorization applies.
|
||||||
|
|
||||||
|
Only one of `name` or `selector` may be specified.
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [name]
|
||||||
|
- required: [selector]
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: References a `Server` instance by name
|
||||||
|
type: string
|
||||||
|
pattern: '^[a-z0-9]([-a-z0-9]*[a-z0-9])?$'
|
||||||
|
selector:
|
||||||
|
description: >-
|
||||||
|
A label query over servers on which this authorization applies.
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [matchLabels]
|
||||||
|
- required: [matchExpressions]
|
||||||
|
properties:
|
||||||
|
matchLabels:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
matchExpressions:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [key, operator]
|
||||||
|
properties:
|
||||||
|
key:
|
||||||
|
type: string
|
||||||
|
operator:
|
||||||
|
type: string
|
||||||
|
enum: [In, NotIn, Exists, DoesNotExist]
|
||||||
|
values:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
client:
|
||||||
|
description: Describes clients authorized to access a server.
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [meshTLS]
|
||||||
|
- required: [unauthenticated]
|
||||||
|
properties:
|
||||||
|
networks:
|
||||||
|
description: >-
|
||||||
|
Limits the client IP addresses to which this
|
||||||
|
authorization applies. If unset, the server chooses a
|
||||||
|
default (typically, all IPs or the cluster's pod
|
||||||
|
network).
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [cidr]
|
||||||
|
properties:
|
||||||
|
cidr:
|
||||||
|
type: string
|
||||||
|
except:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
unauthenticated:
|
||||||
|
description: >-
|
||||||
|
Authorizes unauthenticated clients to access a server.
|
||||||
|
type: boolean
|
||||||
|
meshTLS:
|
||||||
|
type: object
|
||||||
|
oneOf:
|
||||||
|
- required: [unauthenticatedTLS]
|
||||||
|
- required: [identities]
|
||||||
|
- required: [serviceAccounts]
|
||||||
|
properties:
|
||||||
|
unauthenticatedTLS:
|
||||||
|
type: boolean
|
||||||
|
description: >-
|
||||||
|
Indicates that no client identity is required for
|
||||||
|
communication.
|
||||||
|
|
||||||
|
This is mostly important for the identity
|
||||||
|
controller, which must terminate TLS connections
|
||||||
|
from clients that do not yet have a certificate.
|
||||||
|
identities:
|
||||||
|
description: >-
|
||||||
|
Authorizes clients with the provided proxy identity
|
||||||
|
strings (as provided via MTLS)
|
||||||
|
|
||||||
|
The `*` prefix can be used to match all identities in
|
||||||
|
a domain. An identity string of `*` indicates that
|
||||||
|
all authentication clients are authorized.
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
pattern: '^(\*|[a-z0-9]([-a-z0-9]*[a-z0-9])?)(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$'
|
||||||
|
serviceAccounts:
|
||||||
|
description: >-
|
||||||
|
Authorizes clients with the provided proxy identity
|
||||||
|
service accounts (as provided via MTLS)
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: [name]
|
||||||
|
properties:
|
||||||
|
name:
|
||||||
|
description: The ServiceAccount's name.
|
||||||
|
type: string
|
||||||
|
pattern: '^[a-z0-9]([-a-z0-9]*[a-z0-9])?$'
|
||||||
|
namespace:
|
||||||
|
description: >-
|
||||||
|
The ServiceAccount's namespace. If unset, the
|
||||||
|
authorization's namespace is used.
|
||||||
|
type: string
|
||||||
|
pattern: '^[a-z0-9]([-a-z0-9]*[a-z0-9])?$'
|
||||||
|
additionalPrinterColumns:
|
||||||
|
- name: Server
|
||||||
|
type: string
|
||||||
|
description: The server that this grants access to
|
||||||
|
jsonPath: .spec.server.name
|
|
@ -0,0 +1,102 @@
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Proxy Injector RBAC
|
||||||
|
###
|
||||||
|
kind: ClusterRole
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-{{.Values.namespace}}-proxy-injector
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
rules:
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["events"]
|
||||||
|
verbs: ["create", "patch"]
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["namespaces", "replicationcontrollers"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
- apiGroups: [""]
|
||||||
|
resources: ["pods"]
|
||||||
|
verbs: ["list", "watch"]
|
||||||
|
- apiGroups: ["extensions", "apps"]
|
||||||
|
resources: ["deployments", "replicasets", "daemonsets", "statefulsets"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
- apiGroups: ["extensions", "batch"]
|
||||||
|
resources: ["cronjobs", "jobs"]
|
||||||
|
verbs: ["list", "get", "watch"]
|
||||||
|
---
|
||||||
|
kind: ClusterRoleBinding
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-{{.Values.namespace}}-proxy-injector
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-proxy-injector
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
apiGroup: ""
|
||||||
|
roleRef:
|
||||||
|
kind: ClusterRole
|
||||||
|
name: linkerd-{{.Values.namespace}}-proxy-injector
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
---
|
||||||
|
kind: ServiceAccount
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-proxy-injector
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.image-pull-secrets" .Values.imagePullSecrets }}
|
||||||
|
---
|
||||||
|
{{- $host := printf "linkerd-proxy-injector.%s.svc" .Values.namespace }}
|
||||||
|
{{- $ca := genSelfSignedCert $host (list) (list $host) 365 }}
|
||||||
|
{{- if (not .Values.proxyInjector.externalSecret) }}
|
||||||
|
kind: Secret
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-proxy-injector-k8s-tls
|
||||||
|
namespace: {{ .Values.namespace }}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
type: kubernetes.io/tls
|
||||||
|
data:
|
||||||
|
tls.crt: {{ ternary (b64enc (trim $ca.Cert)) (b64enc (trim .Values.proxyInjector.crtPEM)) (empty .Values.proxyInjector.crtPEM) }}
|
||||||
|
tls.key: {{ ternary (b64enc (trim $ca.Key)) (b64enc (trim .Values.proxyInjector.keyPEM)) (empty .Values.proxyInjector.keyPEM) }}
|
||||||
|
---
|
||||||
|
{{- end }}
|
||||||
|
apiVersion: admissionregistration.k8s.io/v1
|
||||||
|
kind: MutatingWebhookConfiguration
|
||||||
|
metadata:
|
||||||
|
name: linkerd-proxy-injector-webhook-config
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
webhooks:
|
||||||
|
- name: linkerd-proxy-injector.linkerd.io
|
||||||
|
namespaceSelector:
|
||||||
|
{{- toYaml .Values.proxyInjector.namespaceSelector | trim | nindent 4 }}
|
||||||
|
clientConfig:
|
||||||
|
service:
|
||||||
|
name: linkerd-proxy-injector
|
||||||
|
namespace: {{ .Values.namespace }}
|
||||||
|
path: "/"
|
||||||
|
{{- if and (.Values.proxyInjector.externalSecret) (empty .Values.proxyInjector.caBundle) }}
|
||||||
|
{{- fail "If proxyInjector.externalSecret is true then you need to provide proxyInjector.caBundle" }}
|
||||||
|
{{- end }}
|
||||||
|
caBundle: {{ ternary (b64enc (trim $ca.Cert)) (b64enc (trim .Values.proxyInjector.caBundle)) (empty .Values.proxyInjector.caBundle) }}
|
||||||
|
failurePolicy: {{.Values.webhookFailurePolicy}}
|
||||||
|
admissionReviewVersions: ["v1", "v1beta1"]
|
||||||
|
rules:
|
||||||
|
- operations: [ "CREATE" ]
|
||||||
|
apiGroups: [""]
|
||||||
|
apiVersions: ["v1"]
|
||||||
|
resources: ["pods", "services"]
|
||||||
|
sideEffects: None
|
|
@ -0,0 +1,163 @@
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Proxy Injector
|
||||||
|
###
|
||||||
|
{{- $tree := deepCopy . }}
|
||||||
|
{{ $_ := set $tree.Values.proxy "workloadKind" "deployment" -}}
|
||||||
|
{{ $_ := set $tree.Values.proxy "component" "linkerd-proxy-injector" -}}
|
||||||
|
{{ include "linkerd.proxy.validation" .Values.proxy -}}
|
||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: proxy-injector
|
||||||
|
app.kubernetes.io/part-of: Linkerd
|
||||||
|
app.kubernetes.io/version: {{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
name: linkerd-proxy-injector
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
replicas: {{.Values.controllerReplicas}}
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
{{- if .Values.enablePodAntiAffinity }}
|
||||||
|
strategy:
|
||||||
|
rollingUpdate:
|
||||||
|
maxUnavailable: 1
|
||||||
|
{{- end }}
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
annotations:
|
||||||
|
{{- if (or (empty .Values.cliVersion) (not (eq (.Values.stage | toString) "control-plane"))) }}
|
||||||
|
checksum/config: {{ include (print $.Template.BasePath "/proxy-injector-rbac.yaml") . | sha256sum }}
|
||||||
|
{{- end }}
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
{{- include "partials.proxy.annotations" . | nindent 8}}
|
||||||
|
{{- with .Values.podAnnotations }}{{ toYaml . | trim | nindent 8 }}{{- end }}
|
||||||
|
config.linkerd.io/opaque-ports: "8443"
|
||||||
|
config.linkerd.io/default-inbound-policy: "all-unauthenticated"
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
linkerd.io/workload-ns: {{.Values.namespace}}
|
||||||
|
{{- include "partials.proxy.labels" $tree.Values.proxy | nindent 8}}
|
||||||
|
{{- with .Values.podLabels }}{{ toYaml . | trim | nindent 8 }}{{- end }}
|
||||||
|
spec:
|
||||||
|
{{- if .Values.tolerations -}}
|
||||||
|
{{- include "linkerd.tolerations" . | nindent 6 }}
|
||||||
|
{{- end -}}
|
||||||
|
{{- include "linkerd.node-selector" . | nindent 6 }}
|
||||||
|
{{- if .Values.enablePodAntiAffinity -}}
|
||||||
|
{{- $local := dict "component" "proxy-injector" "label" -}}
|
||||||
|
{{- include "linkerd.pod-affinity" $local | nindent 6 -}}
|
||||||
|
{{- end }}
|
||||||
|
containers:
|
||||||
|
{{- if not (empty .Values.proxyInjectorProxyResources) }}
|
||||||
|
{{- $r := merge .Values.proxyInjectorProxyResources .Values.proxy.resources }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "resources" $r }}
|
||||||
|
{{- end }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "await" true }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "loadTrustBundleFromConfigMap" true }}
|
||||||
|
{{- $_ := set $tree.Values.proxy "podInboundPorts" "8443,9995" }}
|
||||||
|
{{- /*
|
||||||
|
The pod needs to accept webhook traffic, and we can't rely on that originating in the
|
||||||
|
cluster network.
|
||||||
|
*/}}
|
||||||
|
{{- $_ := set $tree.Values.proxy "defaultInboundPolicy" "all-unauthenticated" }}
|
||||||
|
- {{- include "partials.proxy" $tree | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
- args:
|
||||||
|
- proxy-injector
|
||||||
|
- -log-level={{.Values.controllerLogLevel}}
|
||||||
|
- -log-format={{.Values.controllerLogFormat}}
|
||||||
|
image: {{.Values.controllerImage}}:{{default .Values.linkerdVersion .Values.controllerImageVersion}}
|
||||||
|
imagePullPolicy: {{.Values.imagePullPolicy}}
|
||||||
|
livenessProbe:
|
||||||
|
httpGet:
|
||||||
|
path: /ping
|
||||||
|
port: 9995
|
||||||
|
initialDelaySeconds: 10
|
||||||
|
name: proxy-injector
|
||||||
|
ports:
|
||||||
|
- containerPort: 8443
|
||||||
|
name: proxy-injector
|
||||||
|
- containerPort: 9995
|
||||||
|
name: admin-http
|
||||||
|
readinessProbe:
|
||||||
|
failureThreshold: 7
|
||||||
|
httpGet:
|
||||||
|
path: /ready
|
||||||
|
port: 9995
|
||||||
|
{{- if .Values.proxyInjectorResources -}}
|
||||||
|
{{- include "partials.resources" .Values.proxyInjectorResources | nindent 8 }}
|
||||||
|
{{- end }}
|
||||||
|
securityContext:
|
||||||
|
runAsUser: {{.Values.controllerUID}}
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: /var/run/linkerd/config
|
||||||
|
name: config
|
||||||
|
- mountPath: /var/run/linkerd/identity/trust-roots
|
||||||
|
name: trust-roots
|
||||||
|
- mountPath: /var/run/linkerd/tls
|
||||||
|
name: tls
|
||||||
|
readOnly: true
|
||||||
|
{{ if not .Values.cniEnabled -}}
|
||||||
|
initContainers:
|
||||||
|
- {{- include "partials.proxy-init" $tree | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{ end -}}
|
||||||
|
serviceAccountName: linkerd-proxy-injector
|
||||||
|
volumes:
|
||||||
|
- configMap:
|
||||||
|
name: linkerd-config
|
||||||
|
name: config
|
||||||
|
- configMap:
|
||||||
|
name: linkerd-identity-trust-roots
|
||||||
|
name: trust-roots
|
||||||
|
- name: tls
|
||||||
|
secret:
|
||||||
|
secretName: linkerd-proxy-injector-k8s-tls
|
||||||
|
{{ if not .Values.cniEnabled -}}
|
||||||
|
- {{- include "partials.proxyInit.volumes.xtables" . | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
{{ end -}}
|
||||||
|
- {{- include "partials.proxy.volumes.identity" . | indent 8 | trimPrefix (repeat 7 " ") }}
|
||||||
|
---
|
||||||
|
kind: Service
|
||||||
|
apiVersion: v1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-proxy-injector
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
config.linkerd.io/opaque-ports: "443"
|
||||||
|
spec:
|
||||||
|
type: ClusterIP
|
||||||
|
selector:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
ports:
|
||||||
|
- name: proxy-injector
|
||||||
|
port: 443
|
||||||
|
targetPort: proxy-injector
|
||||||
|
{{- if .Values.enablePodAntiAffinity }}
|
||||||
|
---
|
||||||
|
kind: PodDisruptionBudget
|
||||||
|
apiVersion: policy/v1beta1
|
||||||
|
metadata:
|
||||||
|
name: linkerd-proxy-injector
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
spec:
|
||||||
|
maxUnavailable: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
linkerd.io/control-plane-component: proxy-injector
|
||||||
|
{{- end }}
|
|
@ -0,0 +1,104 @@
|
||||||
|
{{ if .Values.enablePSP -}}
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Control Plane PSP
|
||||||
|
###
|
||||||
|
apiVersion: policy/v1beta1
|
||||||
|
kind: PodSecurityPolicy
|
||||||
|
metadata:
|
||||||
|
name: linkerd-{{.Values.namespace}}-control-plane
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
allowPrivilegeEscalation: false
|
||||||
|
readOnlyRootFilesystem: true
|
||||||
|
{{- if empty .Values.cniEnabled }}
|
||||||
|
allowedCapabilities:
|
||||||
|
- NET_ADMIN
|
||||||
|
- NET_RAW
|
||||||
|
{{- end}}
|
||||||
|
requiredDropCapabilities:
|
||||||
|
- ALL
|
||||||
|
hostNetwork: false
|
||||||
|
hostIPC: false
|
||||||
|
hostPID: false
|
||||||
|
seLinux:
|
||||||
|
rule: RunAsAny
|
||||||
|
runAsUser:
|
||||||
|
{{- if .Values.cniEnabled }}
|
||||||
|
rule: MustRunAsNonRoot
|
||||||
|
{{- else }}
|
||||||
|
rule: RunAsAny
|
||||||
|
{{- end }}
|
||||||
|
supplementalGroups:
|
||||||
|
rule: MustRunAs
|
||||||
|
ranges:
|
||||||
|
{{- if .Values.cniEnabled }}
|
||||||
|
- min: 10001
|
||||||
|
max: 65535
|
||||||
|
{{- else }}
|
||||||
|
- min: 1
|
||||||
|
max: 65535
|
||||||
|
{{- end }}
|
||||||
|
fsGroup:
|
||||||
|
rule: MustRunAs
|
||||||
|
ranges:
|
||||||
|
{{- if .Values.cniEnabled }}
|
||||||
|
- min: 10001
|
||||||
|
max: 65535
|
||||||
|
{{- else }}
|
||||||
|
- min: 1
|
||||||
|
max: 65535
|
||||||
|
{{- end }}
|
||||||
|
volumes:
|
||||||
|
- configMap
|
||||||
|
- emptyDir
|
||||||
|
- secret
|
||||||
|
- projected
|
||||||
|
- downwardAPI
|
||||||
|
- persistentVolumeClaim
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: Role
|
||||||
|
metadata:
|
||||||
|
name: linkerd-psp
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
rules:
|
||||||
|
- apiGroups: ['policy', 'extensions']
|
||||||
|
resources: ['podsecuritypolicies']
|
||||||
|
verbs: ['use']
|
||||||
|
resourceNames:
|
||||||
|
- linkerd-{{.Values.namespace}}-control-plane
|
||||||
|
---
|
||||||
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
|
kind: RoleBinding
|
||||||
|
metadata:
|
||||||
|
name: linkerd-psp
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
roleRef:
|
||||||
|
kind: Role
|
||||||
|
name: linkerd-psp
|
||||||
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
subjects:
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-destination
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
{{ if not .Values.disableHeartBeat -}}
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-heartbeat
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
{{ end -}}
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-identity
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-proxy-injector
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
- kind: ServiceAccount
|
||||||
|
name: linkerd-sp-validator
|
||||||
|
namespace: {{.Values.namespace}}
|
||||||
|
{{ end -}}
|
|
@ -0,0 +1,277 @@
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### Service Profile CRD
|
||||||
|
###
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
name: serviceprofiles.linkerd.io
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
group: linkerd.io
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
served: true
|
||||||
|
storage: false
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
type: object
|
||||||
|
description: Spec is the custom resource spec
|
||||||
|
required:
|
||||||
|
- routes
|
||||||
|
properties:
|
||||||
|
dstOverrides:
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- authority
|
||||||
|
- weight
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
description: WeightedDst is a weighted alternate destination.
|
||||||
|
properties:
|
||||||
|
authority:
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
x-kubernetes-int-or-string: true
|
||||||
|
anyOf:
|
||||||
|
- type: integer
|
||||||
|
- type: string
|
||||||
|
pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
|
||||||
|
opaquePorts:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
retryBudget:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- minRetriesPerSecond
|
||||||
|
- retryRatio
|
||||||
|
- ttl
|
||||||
|
description: RetryBudget describes the maximum number of retries that should be issued to this service.
|
||||||
|
properties:
|
||||||
|
minRetriesPerSecond:
|
||||||
|
format: int32
|
||||||
|
type: integer
|
||||||
|
retryRatio:
|
||||||
|
type: number
|
||||||
|
format: float
|
||||||
|
ttl:
|
||||||
|
type: string
|
||||||
|
routes:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
description: RouteSpec specifies a Route resource.
|
||||||
|
required:
|
||||||
|
- condition
|
||||||
|
- name
|
||||||
|
properties:
|
||||||
|
condition:
|
||||||
|
type: object
|
||||||
|
description: RequestMatch describes the conditions under which to match a Route.
|
||||||
|
properties:
|
||||||
|
pathRegex:
|
||||||
|
type: string
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
all:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
any:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
not:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
isRetryable:
|
||||||
|
type: boolean
|
||||||
|
name:
|
||||||
|
type: string
|
||||||
|
timeout:
|
||||||
|
type: string
|
||||||
|
responseClasses:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- condition
|
||||||
|
description: ResponseClass describes how to classify a response (e.g. success or failures).
|
||||||
|
properties:
|
||||||
|
condition:
|
||||||
|
type: object
|
||||||
|
description: ResponseMatch describes the conditions under
|
||||||
|
which to classify a response.
|
||||||
|
properties:
|
||||||
|
all:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
any:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
not:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
status:
|
||||||
|
type: object
|
||||||
|
description: Range describes a range of integers (e.g. status codes).
|
||||||
|
properties:
|
||||||
|
max:
|
||||||
|
format: int32
|
||||||
|
type: integer
|
||||||
|
min:
|
||||||
|
format: int32
|
||||||
|
type: integer
|
||||||
|
isFailure:
|
||||||
|
type: boolean
|
||||||
|
- name: v1alpha2
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
type: object
|
||||||
|
description: Spec is the custom resource spec
|
||||||
|
properties:
|
||||||
|
dstOverrides:
|
||||||
|
type: array
|
||||||
|
required:
|
||||||
|
- authority
|
||||||
|
- weight
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
description: WeightedDst is a weighted alternate destination.
|
||||||
|
properties:
|
||||||
|
authority:
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
x-kubernetes-int-or-string: true
|
||||||
|
anyOf:
|
||||||
|
- type: integer
|
||||||
|
- type: string
|
||||||
|
pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$
|
||||||
|
opaquePorts:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: string
|
||||||
|
retryBudget:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- minRetriesPerSecond
|
||||||
|
- retryRatio
|
||||||
|
- ttl
|
||||||
|
description: RetryBudget describes the maximum number of retries that should be issued to this service.
|
||||||
|
properties:
|
||||||
|
minRetriesPerSecond:
|
||||||
|
format: int32
|
||||||
|
type: integer
|
||||||
|
retryRatio:
|
||||||
|
type: number
|
||||||
|
format: float
|
||||||
|
ttl:
|
||||||
|
type: string
|
||||||
|
routes:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
description: RouteSpec specifies a Route resource.
|
||||||
|
required:
|
||||||
|
- condition
|
||||||
|
- name
|
||||||
|
properties:
|
||||||
|
condition:
|
||||||
|
type: object
|
||||||
|
description: RequestMatch describes the conditions under which to match a Route.
|
||||||
|
properties:
|
||||||
|
pathRegex:
|
||||||
|
type: string
|
||||||
|
method:
|
||||||
|
type: string
|
||||||
|
all:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
any:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
not:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
isRetryable:
|
||||||
|
type: boolean
|
||||||
|
name:
|
||||||
|
type: string
|
||||||
|
timeout:
|
||||||
|
type: string
|
||||||
|
responseClasses:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- condition
|
||||||
|
description: ResponseClass describes how to classify a response (e.g. success or failures).
|
||||||
|
properties:
|
||||||
|
condition:
|
||||||
|
type: object
|
||||||
|
description: ResponseMatch describes the conditions under
|
||||||
|
which to classify a response.
|
||||||
|
properties:
|
||||||
|
all:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
any:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
not:
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
x-kubernetes-preserve-unknown-fields: true
|
||||||
|
status:
|
||||||
|
type: object
|
||||||
|
description: Range describes a range of integers (e.g. status codes).
|
||||||
|
properties:
|
||||||
|
max:
|
||||||
|
format: int32
|
||||||
|
type: integer
|
||||||
|
min:
|
||||||
|
format: int32
|
||||||
|
type: integer
|
||||||
|
isFailure:
|
||||||
|
type: boolean
|
||||||
|
scope: Namespaced
|
||||||
|
preserveUnknownFields: false
|
||||||
|
names:
|
||||||
|
plural: serviceprofiles
|
||||||
|
singular: serviceprofile
|
||||||
|
kind: ServiceProfile
|
||||||
|
shortNames:
|
||||||
|
- sp
|
|
@ -0,0 +1,95 @@
|
||||||
|
---
|
||||||
|
###
|
||||||
|
### TrafficSplit CRD
|
||||||
|
### Copied from github.com/servicemeshinterface/smi-sdk-go/blob/d4e76b1cd7a33ead5f38d1262dd838a31c80f4e5/crds/split.yaml
|
||||||
|
###
|
||||||
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
metadata:
|
||||||
|
name: trafficsplits.split.smi-spec.io
|
||||||
|
annotations:
|
||||||
|
{{ include "partials.annotations.created-by" . }}
|
||||||
|
labels:
|
||||||
|
linkerd.io/control-plane-ns: {{.Values.namespace}}
|
||||||
|
spec:
|
||||||
|
group: split.smi-spec.io
|
||||||
|
scope: Namespaced
|
||||||
|
conversion:
|
||||||
|
strategy: None
|
||||||
|
names:
|
||||||
|
kind: TrafficSplit
|
||||||
|
listKind: TrafficSplitList
|
||||||
|
shortNames:
|
||||||
|
- ts
|
||||||
|
plural: trafficsplits
|
||||||
|
singular: trafficsplit
|
||||||
|
versions:
|
||||||
|
- name: v1alpha1
|
||||||
|
served: true
|
||||||
|
storage: true
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- service
|
||||||
|
- backends
|
||||||
|
properties:
|
||||||
|
service:
|
||||||
|
description: The apex service of this split.
|
||||||
|
type: string
|
||||||
|
backends:
|
||||||
|
description: The backend services of this split.
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: ['service', 'weight']
|
||||||
|
properties:
|
||||||
|
service:
|
||||||
|
description: Name of the Kubernetes service.
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
description: Traffic weight value of this backend.
|
||||||
|
x-kubernetes-int-or-string: true
|
||||||
|
additionalPrinterColumns:
|
||||||
|
- name: Service
|
||||||
|
type: string
|
||||||
|
description: The apex service of this split.
|
||||||
|
jsonPath: .spec.service
|
||||||
|
- name: v1alpha2
|
||||||
|
served: true
|
||||||
|
storage: false
|
||||||
|
additionalPrinterColumns:
|
||||||
|
- name: Service
|
||||||
|
type: string
|
||||||
|
description: The apex service of this split.
|
||||||
|
jsonPath: .spec.service
|
||||||
|
schema:
|
||||||
|
openAPIV3Schema:
|
||||||
|
type: object
|
||||||
|
properties:
|
||||||
|
spec:
|
||||||
|
type: object
|
||||||
|
required:
|
||||||
|
- service
|
||||||
|
- backends
|
||||||
|
properties:
|
||||||
|
service:
|
||||||
|
description: The apex service of this split.
|
||||||
|
type: string
|
||||||
|
backends:
|
||||||
|
description: The backend services of this split.
|
||||||
|
type: array
|
||||||
|
items:
|
||||||
|
type: object
|
||||||
|
required: ['service', 'weight']
|
||||||
|
properties:
|
||||||
|
service:
|
||||||
|
description: Name of the Kubernetes service.
|
||||||
|
type: string
|
||||||
|
weight:
|
||||||
|
description: Traffic weight value of this backend.
|
||||||
|
type: number
|
||||||
|
preserveUnknownFields: false
|
|
@ -0,0 +1,42 @@
|
||||||
|
# This values.yaml file contains the values needed to enable HA mode.
|
||||||
|
# Usage:
|
||||||
|
# helm install -f values.yaml -f values-ha.yaml
|
||||||
|
|
||||||
|
enablePodAntiAffinity: true
|
||||||
|
|
||||||
|
# proxy configuration
|
||||||
|
proxy:
|
||||||
|
resources:
|
||||||
|
cpu:
|
||||||
|
request: 100m
|
||||||
|
memory:
|
||||||
|
limit: 250Mi
|
||||||
|
request: 20Mi
|
||||||
|
|
||||||
|
# controller configuration
|
||||||
|
controllerReplicas: 3
|
||||||
|
controllerResources: &controller_resources
|
||||||
|
cpu: &controller_resources_cpu
|
||||||
|
limit: ""
|
||||||
|
request: 100m
|
||||||
|
memory:
|
||||||
|
limit: 250Mi
|
||||||
|
request: 50Mi
|
||||||
|
destinationResources: *controller_resources
|
||||||
|
|
||||||
|
# identity configuration
|
||||||
|
identityResources:
|
||||||
|
cpu: *controller_resources_cpu
|
||||||
|
memory:
|
||||||
|
limit: 250Mi
|
||||||
|
request: 10Mi
|
||||||
|
|
||||||
|
# heartbeat configuration
|
||||||
|
heartbeatResources: *controller_resources
|
||||||
|
|
||||||
|
# proxy injector configuration
|
||||||
|
proxyInjectorResources: *controller_resources
|
||||||
|
webhookFailurePolicy: Fail
|
||||||
|
|
||||||
|
# service profile validator configuration
|
||||||
|
spValidatorResources: *controller_resources
|
|
@ -0,0 +1,370 @@
|
||||||
|
# Default values for linkerd.
|
||||||
|
# This is a YAML-formatted file.
|
||||||
|
# Declare variables to be passed into your templates.
|
||||||
|
|
||||||
|
# -- Kubernetes DNS Domain name to use
|
||||||
|
clusterDomain: cluster.local
|
||||||
|
|
||||||
|
# -- 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.
|
||||||
|
clusterNetworks: "10.0.0.0/8,100.64.0.0/10,172.16.0.0/12,192.168.0.0/16"
|
||||||
|
# -- Docker image pull policy
|
||||||
|
imagePullPolicy: IfNotPresent
|
||||||
|
# -- Log level for the control plane components
|
||||||
|
controllerLogLevel: info
|
||||||
|
# -- Log format for the control plane components
|
||||||
|
controllerLogFormat: plain
|
||||||
|
# -- enables control plane tracing
|
||||||
|
controlPlaneTracing: false
|
||||||
|
# -- namespace to send control plane traces to
|
||||||
|
controlPlaneTracingNamespace: linkerd-jaeger
|
||||||
|
# -- control plane version. See Proxy section for proxy version
|
||||||
|
linkerdVersion: stable-2.11.0
|
||||||
|
# -- Control plane namespace
|
||||||
|
namespace: linkerd
|
||||||
|
# -- enables the use of EndpointSlice informers for the destination service;
|
||||||
|
# enableEndpointSlices should be set to true only if EndpointSlice K8s feature
|
||||||
|
# gate is on; the feature is still experimental.
|
||||||
|
enableEndpointSlices: 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
|
||||||
|
cniEnabled: false
|
||||||
|
# -- Trust root certificate (ECDSA). It must be provided during install.
|
||||||
|
identityTrustAnchorsPEM: |
|
||||||
|
# -- Trust domain used for identity
|
||||||
|
# @default -- clusterDomain
|
||||||
|
identityTrustDomain: ""
|
||||||
|
# -- Additional annotations to add to all pods
|
||||||
|
podAnnotations: {}
|
||||||
|
# -- Additional labels to add to all pods
|
||||||
|
podLabels: {}
|
||||||
|
|
||||||
|
# policy controller configuration
|
||||||
|
policyController:
|
||||||
|
# image -- Docker image for the policy controller
|
||||||
|
image:
|
||||||
|
# -- Docker image for the proxy
|
||||||
|
name: cr.l5d.io/linkerd/policy-controller
|
||||||
|
# -- Pull policy for the proxy container Docker image
|
||||||
|
# @default -- imagePullPolicy
|
||||||
|
pullPolicy: ""
|
||||||
|
# -- Tag for the proxy container Docker image
|
||||||
|
# @default -- linkerdVersion
|
||||||
|
version: ""
|
||||||
|
|
||||||
|
# -- The default allow policy to use when no `Server` selects a pod. One of: "all-authenticated",
|
||||||
|
# "all-unauthenticated", "cluster-authenticated", "cluster-unauthenticated", "deny"
|
||||||
|
# @default -- "all-unauthenticated"
|
||||||
|
defaultAllowPolicy: "all-unauthenticated"
|
||||||
|
|
||||||
|
# -- Log level for the policy controller
|
||||||
|
logLevel: linkerd=info,warn
|
||||||
|
|
||||||
|
# -- policy controller resource requests & limits
|
||||||
|
# @default -- destinationResources
|
||||||
|
resources:
|
||||||
|
cpu:
|
||||||
|
# -- Maximum amount of CPU units that the policy controller can use
|
||||||
|
limit: ""
|
||||||
|
# -- Amount of CPU units that the policy controller requests
|
||||||
|
request: ""
|
||||||
|
memory:
|
||||||
|
# -- Maximum amount of memory that the policy controller can use
|
||||||
|
limit: ""
|
||||||
|
# -- Maximum amount of memory that the policy controller requests
|
||||||
|
request: ""
|
||||||
|
|
||||||
|
# proxy configuration
|
||||||
|
proxy:
|
||||||
|
# -- Enable service profiles for non-Kubernetes services
|
||||||
|
enableExternalProfiles: false
|
||||||
|
# -- Maximum time allowed for the proxy to establish an outbound TCP
|
||||||
|
# connection
|
||||||
|
outboundConnectTimeout: 1000ms
|
||||||
|
# -- Maximum time allowed for the proxy to establish an inbound TCP
|
||||||
|
# connection
|
||||||
|
inboundConnectTimeout: 100ms
|
||||||
|
image:
|
||||||
|
# -- Docker image for the proxy
|
||||||
|
name: cr.l5d.io/linkerd/proxy
|
||||||
|
# -- Pull policy for the proxy container Docker image
|
||||||
|
# @default -- imagePullPolicy
|
||||||
|
pullPolicy: ""
|
||||||
|
# -- Tag for the proxy container Docker image
|
||||||
|
# @default -- linkerdVersion
|
||||||
|
version: ""
|
||||||
|
# -- Log level for the proxy
|
||||||
|
logLevel: warn,linkerd=info
|
||||||
|
# -- Log format (`plain` or `json`) for the proxy
|
||||||
|
logFormat: plain
|
||||||
|
ports:
|
||||||
|
# -- Admin port for the proxy container
|
||||||
|
admin: 4191
|
||||||
|
# -- Control port for the proxy container
|
||||||
|
control: 4190
|
||||||
|
# -- Inbound port for the proxy container
|
||||||
|
inbound: 4143
|
||||||
|
# -- Outbound port for the proxy container
|
||||||
|
outbound: 4140
|
||||||
|
# -- 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.
|
||||||
|
cores: 0
|
||||||
|
resources:
|
||||||
|
cpu:
|
||||||
|
# -- Maximum amount of CPU units that the proxy can use
|
||||||
|
limit: ""
|
||||||
|
# -- Amount of CPU units that the proxy requests
|
||||||
|
request: ""
|
||||||
|
memory:
|
||||||
|
# -- Maximum amount of memory that the proxy can use
|
||||||
|
limit: ""
|
||||||
|
# -- Maximum amount of memory that the proxy requests
|
||||||
|
request: ""
|
||||||
|
# -- User id under which the proxy runs
|
||||||
|
uid: 2102
|
||||||
|
# -- If set the proxy sidecar will stay alive for at
|
||||||
|
# least the given period before receiving SIGTERM signal from Kubernetes but
|
||||||
|
# no longer than pod's `terminationGracePeriodSeconds`. See [Lifecycle
|
||||||
|
# hooks](https://kubernetes.io/docs/concepts/containers/container-lifecycle-hooks/#container-hooks)
|
||||||
|
# for more info on container lifecycle hooks.
|
||||||
|
waitBeforeExitSeconds: 0
|
||||||
|
# -- If set, the application container will not start until the proxy is
|
||||||
|
# ready
|
||||||
|
await: true
|
||||||
|
requireIdentityOnInboundPorts: ""
|
||||||
|
# -- 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
|
||||||
|
opaquePorts: "25,587,3306,4444,5432,6379,9300,11211"
|
||||||
|
|
||||||
|
# proxy-init configuration
|
||||||
|
proxyInit:
|
||||||
|
# -- Default set of inbound ports to skip via iptables
|
||||||
|
# - Galera (4567,4568)
|
||||||
|
ignoreInboundPorts: "4567,4568"
|
||||||
|
# -- Default set of outbound ports to skip via iptables
|
||||||
|
# - Galera (4567,4568)
|
||||||
|
ignoreOutboundPorts: "4567,4568"
|
||||||
|
image:
|
||||||
|
# -- Docker image for the proxy-init container
|
||||||
|
name: cr.l5d.io/linkerd/proxy-init
|
||||||
|
# -- Pull policy for the proxy-init container Docker image
|
||||||
|
# @default -- imagePullPolicy
|
||||||
|
pullPolicy: ""
|
||||||
|
# -- Tag for the proxy-init container Docker image
|
||||||
|
version: v1.4.0
|
||||||
|
resources:
|
||||||
|
cpu:
|
||||||
|
# -- Maximum amount of CPU units that the proxy-init container can use
|
||||||
|
limit: 100m
|
||||||
|
# -- Amount of CPU units that the proxy-init container requests
|
||||||
|
request: 10m
|
||||||
|
memory:
|
||||||
|
# -- Maximum amount of memory that the proxy-init container can use
|
||||||
|
limit: 50Mi
|
||||||
|
# -- Amount of memory that the proxy-init container requests
|
||||||
|
request: 10Mi
|
||||||
|
closeWaitTimeoutSecs: 0
|
||||||
|
xtMountPath:
|
||||||
|
mountPath: /run
|
||||||
|
name: linkerd-proxy-init-xtables-lock
|
||||||
|
# -- For Private docker registries, authentication is needed.
|
||||||
|
# Registry secrets are applied to the respective service accounts
|
||||||
|
imagePullSecrets: []
|
||||||
|
# - name: my-private-docker-registry-login-secret
|
||||||
|
|
||||||
|
# -- Allow proxies to perform transparent HTTP/2 upgrading
|
||||||
|
enableH2Upgrade: true
|
||||||
|
|
||||||
|
# -- Add a PSP resource and bind it to the control plane ServiceAccounts. Note
|
||||||
|
# PSP has been deprecated since k8s v1.21
|
||||||
|
enablePSP: false
|
||||||
|
|
||||||
|
# -- Failure policy for the proxy injector
|
||||||
|
webhookFailurePolicy: Ignore
|
||||||
|
|
||||||
|
|
||||||
|
# controllerImage -- Docker image for the destination and identity components
|
||||||
|
controllerImage: cr.l5d.io/linkerd/controller
|
||||||
|
# -- Number of replicas for each control plane pod
|
||||||
|
controllerReplicas: 1
|
||||||
|
# -- User ID for the control plane components
|
||||||
|
controllerUID: 2103
|
||||||
|
|
||||||
|
|
||||||
|
# destination configuration
|
||||||
|
# set resources for the sp-validator and its linkerd proxy respectively
|
||||||
|
# see proxy.resources for details.
|
||||||
|
# destinationResources -- CPU and Memory resources required by destination (see `proxy.resources` for sub-fields)
|
||||||
|
#destinationResources:
|
||||||
|
#destinationProxyResources -- CPU and Memory resources required by proxy
|
||||||
|
# injected into destination pod (see `proxy.resources` for sub-fields)
|
||||||
|
#destinationProxyResources:
|
||||||
|
|
||||||
|
# debug configuration
|
||||||
|
debugContainer:
|
||||||
|
image:
|
||||||
|
# -- Docker image for the debug container
|
||||||
|
name: cr.l5d.io/linkerd/debug
|
||||||
|
# -- Pull policy for the debug container Docker image
|
||||||
|
# @default -- imagePullPolicy
|
||||||
|
pullPolicy: ""
|
||||||
|
# -- Tag for the debug container Docker image
|
||||||
|
# @default -- linkerdVersion
|
||||||
|
version: ""
|
||||||
|
|
||||||
|
identity:
|
||||||
|
# -- If the linkerd-identity-trust-roots ConfigMap has already been created
|
||||||
|
externalCA: false
|
||||||
|
issuer:
|
||||||
|
scheme: linkerd.io/tls
|
||||||
|
|
||||||
|
# -- Amount of time to allow for clock skew within a Linkerd cluster
|
||||||
|
clockSkewAllowance: 20s
|
||||||
|
|
||||||
|
# -- Expiration timestamp for the issuer certificate. It must be provided during install. Must match the expiry date in crtPEM
|
||||||
|
crtExpiry:
|
||||||
|
|
||||||
|
# -- Amount of time for which the Identity issuer should certify identity
|
||||||
|
issuanceLifetime: 24h0m0s
|
||||||
|
|
||||||
|
# -- Which scheme is used for the identity issuer secret format
|
||||||
|
tls:
|
||||||
|
# -- Issuer certificate (ECDSA). It must be provided during install.
|
||||||
|
crtPEM: |
|
||||||
|
|
||||||
|
# -- Key for the issuer certificate (ECDSA). It must be provided during
|
||||||
|
# install
|
||||||
|
keyPEM: |
|
||||||
|
|
||||||
|
|
||||||
|
# -|- CPU and Memory resources required by the identity controller (see `proxy.resources` for sub-fields)
|
||||||
|
#identityResources:
|
||||||
|
# -|- CPU and Memory resources required by proxy injected into identity pod (see `proxy.resources` for sub-fields)
|
||||||
|
#identityProxyResources:
|
||||||
|
|
||||||
|
# heartbeat configuration
|
||||||
|
# disableHeartBeat -- Set to true to not start the heartbeat cronjob
|
||||||
|
disableHeartBeat: false
|
||||||
|
# -- Config for the heartbeat cronjob
|
||||||
|
# heartbeatSchedule: "0 0 * * *"
|
||||||
|
|
||||||
|
# proxy injector configuration
|
||||||
|
proxyInjector:
|
||||||
|
# -- Do not create a secret resource for the profileValidator webhook. If this is set to `true`, the value `proxyInjector.caBundle` must be set (see below)
|
||||||
|
externalSecret: false
|
||||||
|
|
||||||
|
# -- Namespace selector used by admission webhook. If not set defaults to all
|
||||||
|
# namespaces without the annotation
|
||||||
|
# config.linkerd.io/admission-webhooks=disabled
|
||||||
|
namespaceSelector:
|
||||||
|
matchExpressions:
|
||||||
|
- key: config.linkerd.io/admission-webhooks
|
||||||
|
operator: NotIn
|
||||||
|
values:
|
||||||
|
- disabled
|
||||||
|
|
||||||
|
# -- Certificate for the proxy injector. If not provided then Helm will generate one.
|
||||||
|
crtPEM: |
|
||||||
|
|
||||||
|
# -- Certificate key for the proxy injector. If not provided then Helm will generate one.
|
||||||
|
keyPEM: |
|
||||||
|
|
||||||
|
# -- Bundle of CA certificates for proxy injector. If not provided then Helm will use the certificate generated for `proxyInjector.crtPEM`. If `proxyInjector.externalSecret` is set to true, this value must be set, as no certificate will be generated.
|
||||||
|
caBundle: |
|
||||||
|
|
||||||
|
# -|- CPU and Memory resources required by the proxy injector (see
|
||||||
|
#`proxy.resources` for sub-fields)
|
||||||
|
#proxyInjectorResources:
|
||||||
|
#-|- CPU and Memory resources required by proxy injected into the proxy injector
|
||||||
|
#pod (see `proxy.resources` for sub-fields)
|
||||||
|
#proxyInjectorProxyResources:
|
||||||
|
|
||||||
|
# service profile validator configuration
|
||||||
|
profileValidator:
|
||||||
|
# -- Do not create a secret resource for the profileValidator webhook. If this is set to `true`, the value `profileValidator.caBundle` must be set (see below).
|
||||||
|
externalSecret: false
|
||||||
|
|
||||||
|
# -- Namespace selector used by admission webhook
|
||||||
|
namespaceSelector:
|
||||||
|
matchExpressions:
|
||||||
|
- key: config.linkerd.io/admission-webhooks
|
||||||
|
operator: NotIn
|
||||||
|
values:
|
||||||
|
- disabled
|
||||||
|
|
||||||
|
# -- Certificate for the service profile validator. If not provided then Helm
|
||||||
|
# will generate one.
|
||||||
|
crtPEM: |
|
||||||
|
|
||||||
|
# -- Certificate key for the service profile validator. If not provided then
|
||||||
|
# Helm will generate one.
|
||||||
|
keyPEM: |
|
||||||
|
|
||||||
|
# -- Bundle of CA certificates for service profile validator. If not provided
|
||||||
|
# then Helm will use the certificate generated for `profileValidator.crtPEM`.
|
||||||
|
# If `profileValidator.externalSecret` is set to true, this value must be set,
|
||||||
|
# as no certificate will be generated.
|
||||||
|
caBundle: |
|
||||||
|
|
||||||
|
# policy validator configuration
|
||||||
|
policyValidator:
|
||||||
|
# -- Do not create a secret resource for the policyValidator webhook. If this is set to `true`, the value `policyValidator.caBundle` must be set (see below).
|
||||||
|
externalSecret: false
|
||||||
|
|
||||||
|
# -- Namespace selector used by admission webhook
|
||||||
|
namespaceSelector:
|
||||||
|
matchExpressions:
|
||||||
|
- key: config.linkerd.io/admission-webhooks
|
||||||
|
operator: NotIn
|
||||||
|
values:
|
||||||
|
- disabled
|
||||||
|
|
||||||
|
# -- Certificate for the policy validator. If not provided then Helm
|
||||||
|
# will generate one.
|
||||||
|
crtPEM: |
|
||||||
|
|
||||||
|
# -- Certificate key for the policy validator. If not provided then
|
||||||
|
# Helm will generate one.
|
||||||
|
keyPEM: |
|
||||||
|
|
||||||
|
# -- Bundle of CA certificates for policy validator. If not provided
|
||||||
|
# then Helm will use the certificate generated for `policyValidator.crtPEM`.
|
||||||
|
# If `policyValidator.externalSecret` is set to true, this value must be set,
|
||||||
|
# as no certificate will be generated.
|
||||||
|
caBundle: |
|
||||||
|
|
||||||
|
# -|- CPU and Memory resources required by the SP validator (see
|
||||||
|
#`proxy.resources` for sub-fields)
|
||||||
|
#spValidatorResources:
|
||||||
|
|
||||||
|
# If the namespace is controlled by an external tool or can't be installed with Helm
|
||||||
|
# you can disable its installation. In this case:
|
||||||
|
# - The namespace created by the external tool must match the namespace value above
|
||||||
|
# - The external tool needs to create the namespace with the label:
|
||||||
|
# config.linkerd.io/admission-webhooks: disabled
|
||||||
|
|
||||||
|
# installNamespace -- Set to false when installing Linkerd in a custom namespace. See the
|
||||||
|
# [Linkerd documentation](https://linkerd.io/2/tasks/install-helm#customizing-the-namespace) for more information.
|
||||||
|
installNamespace: true
|
||||||
|
|
||||||
|
# -- NodeSelector section, See the [K8S
|
||||||
|
# documentation](https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#nodeselector)
|
||||||
|
# for more information
|
||||||
|
nodeSelector:
|
||||||
|
beta.kubernetes.io/os: linux
|
||||||
|
|
||||||
|
# -|- Tolerations section, See the
|
||||||
|
# [K8S documentation](https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/)
|
||||||
|
# for more information
|
||||||
|
#tolerations:
|
31
index.yaml
31
index.yaml
|
@ -1202,6 +1202,37 @@ entries:
|
||||||
urls:
|
urls:
|
||||||
- assets/kong/kong-2.3.1.tgz
|
- assets/kong/kong-2.3.1.tgz
|
||||||
version: 2.3.1
|
version: 2.3.1
|
||||||
|
linkerd2:
|
||||||
|
- annotations:
|
||||||
|
catalog.cattle.io/certified: partner
|
||||||
|
catalog.cattle.io/display-name: Linkerd
|
||||||
|
catalog.cattle.io/release-name: linkerd
|
||||||
|
apiVersion: v1
|
||||||
|
appVersion: stable-2.11.0
|
||||||
|
created: "2021-09-30T17:11:34.121631235-05:00"
|
||||||
|
dependencies:
|
||||||
|
- name: partials
|
||||||
|
repository: file://../partials
|
||||||
|
version: 0.1.0
|
||||||
|
description: |
|
||||||
|
Linkerd gives you observability, reliability, and security
|
||||||
|
for your microservices — with no code change required.
|
||||||
|
digest: 1c5f3b2c1fdaf34db6bb08fc0f9d234f35946c15d025e223519530397b225327
|
||||||
|
home: https://linkerd.io
|
||||||
|
icon: https://linkerd.io/images/logo-only-200h.png
|
||||||
|
keywords:
|
||||||
|
- service-mesh
|
||||||
|
kubeVersion: '>=1.16.0-0'
|
||||||
|
maintainers:
|
||||||
|
- email: cncf-linkerd-dev@lists.cncf.io
|
||||||
|
name: Linkerd authors
|
||||||
|
url: https://linkerd.io/
|
||||||
|
name: linkerd2
|
||||||
|
sources:
|
||||||
|
- https://github.com/linkerd/linkerd2/
|
||||||
|
urls:
|
||||||
|
- assets/linkerd/linkerd2-2.11.0.tgz
|
||||||
|
version: 2.11.0
|
||||||
neuvector:
|
neuvector:
|
||||||
- annotations:
|
- annotations:
|
||||||
catalog.cattle.io/certified: partner
|
catalog.cattle.io/certified: partner
|
||||||
|
|
Loading…
Reference in New Issue