The module is not enabled by default in any bundles.
The module is configured using the ModuleConfig custom resource named istio
(learn more about setting up Deckhouse…).
Example of the ModuleConfig/istio
resource for configuring the module:
apiVersion: deckhouse.io/v1alpha1
kind: ModuleConfig
metadata:
name: istio
spec:
version: 2
enabled: true
settings: # <-- Module parameters from the "Parameters" section below.
Parameters
Schema version: 2
- additionalVersions
Additional versions of Istio control plane to install. You can use specific namespace labels (
istio.io/rev=
) to switch between installed revisions.Default:
[]
- Element of the array
Pattern:
^[0-9]+\.[0-9]+$
- alliance
Common options both for federation and multicluster.
This feature is available in enterprise edition only.
- alliance.ingressGateway
ingressgateway settings.
This feature is available in enterprise edition only.
- alliance.ingressGateway.inlet
The method for exposing ingressgateway.
LoadBalancer
— is a recommended method if you have a cloud-based cluster and it supports Load Balancing.NodePort
— for installations that do not have the LB.
Default:
"LoadBalancer"
This feature is available in enterprise edition only.
Allowed values:
LoadBalancer
,NodePort
Example:
inlet: LoadBalancer
- alliance.ingressGateway.nodePort
Special settings for NodePort inlet.
This feature is available in enterprise edition only.
Examples:
nodePort: {}
nodePort: port: 30001
- alliance.ingressGateway.nodePort.port
Static port number for NodePort-type Service. Must be in range, set by kube-apiserver –service-node-port-range argument (default is 30000-32767).
Allowed values:
1024 <= X <= 65535
- alliance.ingressGateway.nodeSelector
ingressgateway DaemonSet nodeSelector.
The same as the
spec.nodeSelector
pod parameter in Kubernetes.This feature is available in enterprise edition only.
Example:
nodeSelector: type: ingress
- alliance.ingressGateway.serviceAnnotations
Additional service annotations. They can be used, e.g., for configuring a local LB in the Yandex Cloud (using the
yandex.cpi.flant.com/listener-subnet-id
annotation).This feature is available in enterprise edition only.
Example:
serviceAnnotations: yandex.cpi.flant.com/listener-subnet-id: xyz-123
- alliance.ingressGateway.tolerations
ingressgateway DaemonSet tolerations.
The same as
spec.tolerations
for the Kubernetes pod.This feature is available in enterprise edition only.
Example:
tolerations: - operator: Exists
- alliance.ingressGateway.tolerations.effect
- alliance.ingressGateway.tolerations.key
- alliance.ingressGateway.tolerations.operator
- alliance.ingressGateway.tolerations.tolerationSeconds
- alliance.ingressGateway.tolerations.value
- auth
Options related to authentication or authorization in the application.
Example:
auth: externalAuthentication: authURL: https://dex.d8.svc.cluster.local/dex/auth authSignInURL: https://example.com/dex/sign_in allowedUserGroups: - admins
- auth.allowedUserGroups
An array of user groups that can access module’s public web interfaces.
This parameter is used if the
user-authn
module is enabled or theexternalAuthentication
parameter is set.Caution! Note that you must add those groups to the appropriate field in the DexProvider config if this module is used together with the user-authn one.
- auth.externalAuthentication
Parameters to enable external authentication based on the NGINX Ingress external-auth mechanism that uses the Nginx auth_request module.
External authentication is enabled automatically if the user-authn module is enabled.
- auth.externalAuthentication.authSignInURL
The URL to redirect the user for authentication (if the authentication service returned a non-200 HTTP response code).
Example:
authSignInURL: https://example.com/dex/sign_in
- auth.externalAuthentication.authURL
The URL of the authentication service.
If the user is authenticated, the service should return an HTTP 200 response code.
Example:
authURL: https://example.com/dex/auth
- auth.satisfyAny
Enables single authentication.
If used together with the whitelistSourceRanges parameter, it authorizes all the users from above networks (no need to enter a username and password).
Default:
false
Example:
satisfyAny: true
- auth.whitelistSourceRanges
An array if CIDRs that are allowed to authenticate in module’s public web interfaces.
Example:
whitelistSourceRanges: - 1.1.1.1/32
- ca
Explicitly specified root certificate. It signs individual service certificates to use in mutual TLS connections.
- ca.cert
The root or intermediate certificate in PEM format.
- ca.chain
A certificate chain in PEM format if
cert
is an intermediate certificate. - ca.key
The key to the root certificate in PEM format.
- ca.root
The root certificate in PEM format if
cert
is an intermediate certificate.
- controlPlane
istiod specific settings.
- controlPlane.nodeSelector
Optional
nodeSelector
for istiod. The same as thespec.nodeSelector
pod parameter in Kubernetes.If the parameter is omitted or
false
, it will be determined automatically. - controlPlane.replicasManagement
Replication management settings and scaling of istiod.
Examples:
replicasManagement: mode: Standard
replicasManagement: mode: Static static: replicas: 3
replicasManagement: mode: HPA hpa: minReplicas: 2 maxReplicas: 5 metrics: - type: CPU targetAverageUtilization: 80
- controlPlane.replicasManagement.hpa
Options for replicas management for the
HPA
mode.- controlPlane.replicasManagement.hpa.maxReplicas
Required value
The upper limit for the number of replicas to which the HPA can scale up. It cannot be less that
minReplicas
.Allowed values:
1 <= X
- controlPlane.replicasManagement.hpa.metrics
Required value
The HPA will use these metrics to decide whether to increase or decrease the number of replicates.
- controlPlane.replicasManagement.hpa.metrics.targetAverageUtilization
Required value
The target value of the average of the resource metric across all relevant pods, represented as a percentage of the requested value of the resource for the pods.
Allowed values:
1 <= X <= 100
- controlPlane.replicasManagement.hpa.metrics.type
Required value
Metric type.
Allowed values:
CPU
- controlPlane.replicasManagement.hpa.minReplicas
Required value
The lower limit for the number of replicas to which the HPA can scale down.
Allowed values:
1 <= X
- controlPlane.replicasManagement.mode
Replicas management mode:
Standard
— replicas management and scaling mode according to the global fault tolerance mode (the highAvailability parameter);Static
— the mode, where the number of replicas is specified explicitly (the static.replicas parameter);HPA
— the mode, where the number of replicas is calculated automatically using HPA based on CPU usage. You can configure this mode by modifying parameters in the hpa parameter section.
Default:
"Standard"
Allowed values:
Standard
,Static
,HPA
- controlPlane.replicasManagement.static
Options for replicas management for the
Static
mode.- controlPlane.replicasManagement.static.replicas
Required value
Desired number of replicas.
Allowed values:
1 <= X
- controlPlane.resourcesManagement
Settings for CPU and memory requests and limits by istiod pods.
Examples:
resourcesManagement: mode: VPA vpa: mode: Auto cpu: min: 50m max: 2 limitRatio: 1.5 memory: min: 256Mi max: 2Gi limitRatio: 1.5
resourcesManagement: mode: Static static: requests: cpu: 55m memory: 256Mi limits: cpu: '2' memory: 2Gi
- controlPlane.resourcesManagement.mode
Resource management mode:
Default:
"VPA"
Allowed values:
VPA
,Static
- controlPlane.resourcesManagement.static
Resource management options for the
Static
mode.- controlPlane.resourcesManagement.static.limits
Configuring CPU and memory limits.
- controlPlane.resourcesManagement.static.limits.cpu
Configuring CPU limits.
- controlPlane.resourcesManagement.static.limits.memory
Configuring memory limits.
- controlPlane.resourcesManagement.static.requests
Resource requests settings for pods.
- controlPlane.resourcesManagement.static.requests.cpu
Configuring CPU requests.
- controlPlane.resourcesManagement.static.requests.memory
Configuring memory requests.
- controlPlane.resourcesManagement.vpa
Resource management options for the
VPA
mode.- controlPlane.resourcesManagement.vpa.cpu
CPU-related VPA settings.
- controlPlane.resourcesManagement.vpa.cpu.limitRatio
The CPU limits/requests ratio.
This ratio is used for calculating the initial CPU limits for a pod.
If this parameter is set, the VPA will recalculate the CPU limits while maintaining the specified limits/requests ratio.
- controlPlane.resourcesManagement.vpa.cpu.max
The maximum value that the VPA can set for the CPU requests.
Default:
2
- controlPlane.resourcesManagement.vpa.cpu.min
The minimum value that the VPA can set for the CPU requests.
Default:
50m
- controlPlane.resourcesManagement.vpa.memory
Memory-related VPA settings.
- controlPlane.resourcesManagement.vpa.memory.limitRatio
The memory limits/requests ratio.
This ratio is used for calculating the initial memory limits for a pod.
If this parameter is set, the VPA will recalculate the memory limits while maintaining the specified limits/requests ratio.
- controlPlane.resourcesManagement.vpa.memory.max
The maximum memory requests the VPA can set.
Default:
2Gi
- controlPlane.resourcesManagement.vpa.memory.min
The minimum memory requests the VPA can set.
Default:
256Mi
- controlPlane.resourcesManagement.vpa.mode
VPA operating mode.
Default:
"Auto"
Allowed values:
Initial
,Auto
- controlPlane.tolerations
Optional
tolerations
for istiod. The same asspec.tolerations
for the Kubernetes pod.If the parameter is omitted or
false
, it will be determined automatically.- controlPlane.tolerations.effect
- controlPlane.tolerations.key
- controlPlane.tolerations.operator
- controlPlane.tolerations.tolerationSeconds
- controlPlane.tolerations.value
- dataPlane
- dataPlane.trafficRedirectionSetupMode
Managing the redirection mode of application traffic to be forwarded under Istio control in the Pod’s network namespace.
CNIPlugin
— in this mode, the configuration is performed by a CNI plugin when creating a Pod on a node. This mode does not require additional permissions for Pods and is recommended. This mode has limitations when using application init-containers that perform network communication with other services.InitContainer
— classic mode, each application Pod is automatically injected with a special init-container that configures the network environment of the Pod. In order to perform this configuration, the init-container is given additional permissions, which may not meet the security requirements of individual installations.
Default:
"InitContainer"
Allowed values:
CNIPlugin
,InitContainer
Examples:
trafficRedirectionSetupMode: CNIPlugin
trafficRedirectionSetupMode: InitContainer
- enableHTTP10
Whether to handle HTTP/1.0 requests in istio-sidecars or deny them with
426 Upgrade Required
response.Default:
false
Example:
enableHTTP10: true
- federation
Parameters for federating with other clusters.
This feature is available in enterprise edition only.
- federation.enabled
Designate this cluster as a federation member (see Enabling federation).
Default:
false
Example:
enabled: true
- globalVersion
Specific version of Istio control-plane which handles unspecific versions of data plane (namespaces with
istio-injection=enabled
label, notistio.io/rev=
).Default:
"1.19"
Pattern:
^[0-9]+\.[0-9]+$
- highAvailability
Manually enable the high availability mode.
By default, Deckhouse automatically decides whether to enable the HA mode. Click here to learn more about the HA mode for modules.
Example:
highAvailability: true
- https
What certificate type to use with module’s public web interfaces.
This parameter completely overrides the
global.modules.https
settings.Examples:
https: mode: CustomCertificate customCertificate: secretName: foobar
https: mode: CertManager certManager: clusterIssuerName: letsencrypt
- https.certManager
- https.certManager.clusterIssuerName
What ClusterIssuer to use for Kiali/metadata-exporter (including SPIFFE endpoint)/api-proxy.
Currently,
letsencrypt
,letsencrypt-staging
,selfsigned
are available. Also, you can define your own.Default:
"letsencrypt"
- https.customCertificate
- https.customCertificate.secretName
The name of the secret in the
d8-system
namespace to use with Kiali/metadata-exporter (including SPIFFE endpoint)/api-proxy.This secret must have the kubernetes.io/tls format.
Default:
"false"
- https.mode
The HTTPS usage mode:
CertManager
— Kiali/metadata-exporter (including SPIFFE endpoint)/api-proxy will use HTTPS and get a certificate from the clusterissuer defined in thecertManager.clusterIssuerName
parameter.CustomCertificate
— Kiali/metadata-exporter (including SPIFFE endpoint)/api-proxy will use HTTPS using the certificate from thed8-system
namespace.OnlyInURI
— Kiali/metadata-exporter (including SPIFFE endpoint)/api-proxy will work over HTTP (thinking that there is an external HTTPS load balancer in front that terminates HTTPS traffic). All the links in theuser-authn
will be generated using the HTTPS scheme. Load balancer should provide a redirect from HTTP to HTTPS.
Caution! Unlike other modules, Istio doesn’t support non-secured HTTP (
mode: Disabled
).Default:
"CertManager"
Allowed values:
CertManager
,CustomCertificate
,OnlyInURI
- ingressClass
The class of the Ingress controller used for Kiali, metadata-exporter and proxy-api.
Optional. By default, the
modules.ingressClass
global value is used.Pattern:
^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$
- multicluster
Multicluster parameters.
This feature is available in enterprise edition only.
- multicluster.enabled
Designate this cluster as a multicluster member (see Enabling multicluster).
Default:
false
Example:
enabled: true
- nodeSelector
Optional
nodeSelector
for istio-operator, metadata-exporter and Kiali. The same as thespec.nodeSelector
pod parameter in Kubernetes.If the parameter is omitted or
false
, it will be determined automatically. - outboundTrafficPolicyMode
How to handle requests directed to external services which aren’t registered in service mesh.
AllowAny
— allow.RegistryOnly
— deny. In this case to work with external services you need to register them with ServiceEntry custom resource or to organize egressgateway.
Default:
"AllowAny"
Allowed values:
AllowAny
,RegistryOnly
Example:
outboundTrafficPolicyMode: AllowAny
- proxyConfig.holdApplicationUntilProxyStarts
With this feature, the sidecar-injector injects the sidecar at the first place of Pod’s container list and adds a postStart hook to be sure if the Envoy proxy is initialized before the application. So the Envoy is able to handle requests without application network errors.
This global flag can be overriden per Pod by an annotation —
proxy.istio.io/config: '{ "holdApplicationUntilProxyStarts": true }'
.Default:
false
Example:
holdApplicationUntilProxyStarts: true
- proxyConfig.idleTimeout
Timeout for connections without application activity established between the client’s istio-sidecar and the service. When the timeout expires, the connection between the sidecar and the service is closed, but the connection between the application and the sidecar is not closed. If set to
0s
, the timeout is disabled.This global flag can be overriden per Pod by an annotation:
proxy.istio.io/config: |- proxyMetadata: ISTIO_META_IDLE_TIMEOUT: "12h"
Warning! Disabling this timeout (setting the value to
0s
) is very likely to result in leaky connections due to TCP FIN packet loss, etc. Warning! After changing this setting, a restart of the client pods is required.Default:
"1h"
Pattern:
^[0-9]+(s|m|h)$
Example:
idleTimeout: 24h
- sidecar
Network settings for traffic capture by istio sidecar.
- sidecar.excludeInboundPorts
The range of inbound ports whose traffic is guaranteed not to flow through Istio.
You can redefine this parameter for single Pod using the
traffic.sidecar.istio.io/excludeInboundPorts
annotation.Default:
[]
Example:
excludeInboundPorts: - '8080' - '8443'
- Element of the array
Pattern:
^[0-9]{1,5}$
- sidecar.excludeOutboundIPRanges
Traffic to these IP ranges is guaranteed not to flow through Istio.
You can redefine this parameter for single Pod using the
traffic.sidecar.istio.io/excludeOutboundIPRanges
annotation.Default:
[]
Example:
excludeOutboundIPRanges: - 10.1.1.0/24
- Element of the array
Pattern:
^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}/[0-9]{1,2}$
- sidecar.excludeOutboundPorts
The range of outbound ports whose traffic is guaranteed not to flow through Istio.
You can redefine this parameter for single Pod using the
traffic.sidecar.istio.io/excludeOutboundPorts
annotation.Default:
[]
Example:
excludeOutboundPorts: - '8080' - '8443'
- Element of the array
Pattern:
^[0-9]{1,5}$
- sidecar.includeOutboundIPRanges
Traffic to these IP ranges is forcibly routed through Istio.
You can redefine this parameter for single Pod using the
traffic.sidecar.istio.io/includeOutboundIPRanges
annotation.Default:
["0.0.0.0/0"]
Example:
includeOutboundIPRanges: - 10.1.1.0/24
- Element of the array
Pattern:
^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}/[0-9]{1,2}$
- sidecar.resourcesManagement
Manages Istio sidecar container resources.
Caution! The setting only applies to new Pods with
istio-proxy
.Example:
resourcesManagement: static: requests: cpu: 100m memory: 128Mi limits: memory: 1Gi
- sidecar.resourcesManagement.mode
The mode for managing resource requests. Classical
Static
requests/limit.Default:
"Static"
Allowed values:
Static
- sidecar.resourcesManagement.static
Static resource management settings.
- sidecar.resourcesManagement.static.limits
Limits configuration.
- sidecar.resourcesManagement.static.limits.cpu
CPU limits.
- sidecar.resourcesManagement.static.limits.memory
Memory limits.
Default:
1Gi
- sidecar.resourcesManagement.static.requests
Requests configuration.
- sidecar.resourcesManagement.static.requests.cpu
CPU requests.
Default:
100m
- sidecar.resourcesManagement.static.requests.memory
Memory requests.
Default:
128Mi
- tolerations
Optional
tolerations
for istio-operator, metadata-exporter and Kiali. The same asspec.tolerations
for the Kubernetes pod.If the parameter is omitted or
false
, it will be determined automatically.- tolerations.effect
- tolerations.key
- tolerations.operator
- tolerations.tolerationSeconds
- tolerations.value
- tracing
Tracing parameters.
- tracing.collector
Tracing collection settings.
- tracing.collector.zipkin
Zipkin protocol parameters used by Istio for sending traces. Jaeger supports this protocol.
If tracing is enabled, this settings section is mandatory.
- tracing.collector.zipkin.address
Network address of zipkin collector in
<IP of FQDN>:<port>
format.Pattern:
[0-9a-zA-Z\.-]+
Example:
address: zipkin.myjaeger.svc:9411
- tracing.enabled
Turn on or off tracing collection and displaying in Kiali.
Default:
false
Example:
enabled: true
- tracing.kiali
Span displaying settings for Kiali.
When not configured, Kiali won’t show any tracing dashboards.
Examples:
kiali: {}
kiali: jaegerURLForUsers: https://tracing-service:4443/jaeger jaegerGRPCEndpoint: http://tracing.myjaeger.svc:16685/
- tracing.kiali.jaegerGRPCEndpoint
Accessible from cluster address of jaeger GRPC interface for system queries by Kiali.
When not configured, Kiali will only show external links using the
jaegerURLForUsers
config without interpretationing.Example:
jaegerGRPCEndpoint: http://tracing.myjaeger.svc:16685/
- tracing.kiali.jaegerURLForUsers
Jaeger UI address for users. Mandatory parameter if Kiali is enabled.
Example:
jaegerURLForUsers: https://tracing-service:4443/jaeger
- tracing.sampling
The sampling rate option can be used to control what percentage of requests get reported to your tracing system.
This should be configured depending upon your traffic in the mesh and the amount of tracing data you want to collect.
It is possible to override this option with the following Pod annotation:
proxy.istio.io/config: | tracing: sampling: 100.0
Default:
1.0
Allowed values:
0.01 <= X <= 100.0
Example:
sampling: 50.05
Authentication
user-authn module provides authentication by default. Also, externalAuthentication can be configured (see below). If these options are disabled, the module will use basic auth with the auto-generated password.
Use kubectl to see password:
kubectl -n d8-system exec deploy/deckhouse -- deckhouse-controller module values istio -o json | jq '.istio.internal.auth.password'
Delete the Secret to re-generate password:
kubectl -n d8-istio delete secret/kiali-basic-auth
Note! The
auth.password
parameter is deprecated.