-
Notifications
You must be signed in to change notification settings - Fork 14.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
how to start using sidecar containers
- Loading branch information
1 parent
e1669dd
commit 6727ef5
Showing
3 changed files
with
116 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
114 changes: 114 additions & 0 deletions
114
content/en/docs/tutorials/configuration/pod-sidecar-containers.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,114 @@ | ||
--- | ||
title: Adopting Sidecar Containers | ||
content_type: tutorial | ||
weight: 40 | ||
--- | ||
|
||
<!-- overview --> | ||
|
||
This section is relevant for people adopting [sidecar containers](/docs/concepts/workloads/pods/sidecar-containers/) for their workloads. | ||
|
||
{{< feature-state for_k8s_version="v1.29" state="beta" >}} | ||
|
||
## {{% heading "objectives" %}} | ||
|
||
|
||
* Be able to troubleshoot issues with the Sidecar Containers | ||
* Understand options to universally "inject" Sidecar Containers to any workload | ||
|
||
|
||
## {{% heading "prerequisites" %}} | ||
|
||
|
||
{{< include "task-tutorial-prereqs.md" >}} {{< version-check >}} | ||
|
||
* This tutorial is relevant for clusters version 1.29+ | ||
* Understand the concept of [sidecar containers](/docs/concepts/workloads/pods/sidecar-containers/) | ||
|
||
|
||
<!-- lessoncontent --> | ||
|
||
|
||
## Adopting sidecar containers | ||
|
||
The `SidecarContainers` feature is in beta state starting Kubernetes version `1.29` and is enabled by default. | ||
Some clusters may have this feature disabled or have software installed that is incompatible with the feature. | ||
Here are the considerations and troubleshooting steps that one can take while adopting sidecar containers for their workload. | ||
|
||
**1. Ensure the feature gate is enabled.** | ||
|
||
As a very first step, make sure that both - API server and Nodes were upgraded to the version `1.29+`. | ||
The feature will break on clusters where Nodes are running earlier versions where it is not enabled. | ||
|
||
The feature gate enablement should also be validated for both - API server AND Nodes. | ||
|
||
One of the ways to check the feature gate enablement is running a command like this: | ||
|
||
- For API Server | ||
`kubectl get --raw /metrics | grep kubernetes_feature_enabled | grep SidecarContainers` | ||
- For the individual node: | ||
`kubectl get --raw /api/v1/nodes/<node-name>/proxy/metrics | grep kubernetes_feature_enabled | grep SidecarContainers` | ||
|
||
If you see something like: `kubernetes_feature_enabled{name="SidecarContainers",stage="BETA"} 1`, | ||
it means that the feature is enabled. | ||
|
||
**2. Check for 3rd party tooling and mutating webhooks** | ||
|
||
If you experience issues when validating the feature, it may be an indication that one of the | ||
3rd party tools or mutating webhooks are broken. | ||
|
||
The `SidecarContainers` feature adds a new field that is define in Kubernetes `1.28` API. | ||
Some tools or mutating webhooks might have been built with an earlier version of Kubernetes API. | ||
If tools pass the unknown fields as-is or mutating webhooks are using the recommended `Patch` method to mutate Pods, it will not be a problem. | ||
|
||
However there are tools that will strip out unknown fields and must be recompiled with the v1.28+ version of Kubernetes API. | ||
|
||
The way to check this is to use the `kubectl describe pod` command with your Pod. | ||
If any tools stripped out the new field (`restartPolicy:Always`), you will not find see it in the command output. | ||
|
||
If you hit an issue like this, please advise the author of the tools or the webhooks to switch to `Patch` method of modifying objects. | ||
|
||
{{% alert title="Note" color="info" %}} | ||
|
||
Mutating webhook may update Pods based on some conditions. So sidecar containers may work for some Pods and fail for others. | ||
|
||
{{% /alert %}} | ||
|
||
**3. Automatic injection of sidecars** | ||
|
||
If you are using software that injects sidecars automatically, | ||
there are a few possible strategies you may follow to | ||
ensure that native sidecar container can be used. | ||
All of the strategies are generally options you may choose to decide whether | ||
the Pod the sidecar will be injected to will land on a Node supporting the feature or not. | ||
|
||
As an example, you can follow this conversation: https://github.com/istio/istio/issues/48794 | ||
|
||
1. Mark Pods that lands to nodes supporting sidecars. You can use node labels | ||
and node affinity to mark nodes supporting sidecar containers and Pods landing on those nodes. | ||
2. Check Nodes compatibility on injection. During sidecar injection you may use the following strategies to check node compatibility: | ||
- query node version and assume the feature gate is enabled on the version 1.29+ | ||
- query node prometheus metrics and check feature enablement status | ||
- assume the nodes are running in a [supported version skew](https://kubernetes.io/releases/version-skew-policy/#supported-version-skew). | ||
If API version is 1.32+, assume all the nodes support the feature. | ||
- there may be other custom ways to detect nodes compatibility. | ||
3. Develop a universal sidecar injector. The idea of a universal sidecar container is to inject a sidecar container | ||
as a regular container as well as a native sidecar container. And have a runtime logic to decide which one will work. | ||
The universal sidecar injector is wasteful as it will account for requests twice, but may be considered as a workable solution for special cases. | ||
- One way would be on start of a native sidecar container | ||
detect the node version and exit immediately if the version does not support the sidecar feature. | ||
- Consider runtime feature detection design: | ||
- Define an empty dir so containers can communicate with each other | ||
- Inject init container `NativeSidecar` with `restartPolicy=Always`. | ||
- `NativeSidecar` must write a file to an empty dir indicating the first run and exists immediately with exit code `0`. | ||
- `NativeSidecar` on restart (when native sidecars are supported) checks that file already exists in the empty dir and changes it - indicating that the built-in sidecar containers are supported and running. | ||
- Inject regular container `OldWaySidecar`. | ||
- `OldWaySidecar` on start checks the presence of a file in an empty dir. | ||
- If the file indicates that the `NativeSidecar` is NOT running - it assumes that the sidecar feature is not supported and works assuming it is the sidecar. | ||
- If the file indicates that the `NativeSidecar` is running - it either does nothing and sleeps forever (in case when Pod’s `restartPolicy=Always`) or exists immediately with exit code `0` (in case when Pod’s `restartPolicy!=Always`). | ||
|
||
|
||
## {{% heading "whatsnext" %}} | ||
|
||
|
||
* Learn more about [SidecarContainers](/docs/tasks/configure-pod-container/configure-pod-configmap/). |