-
Notifications
You must be signed in to change notification settings - Fork 40.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Move init-container feature from alpha to beta. #31026
Conversation
```relnote Moved init-container feature from alpha to beta. In 1.3, an init container is specified with this annotation key on the pod or pod template: `pods.alpha.kubernetes.io/init-containers`. In 1.4, either that key or this key: pods.beta.kubernetes.io/init-containers`, can be used. When you GET an object, you will see both annotation keys with the same values. You can safely roll back from 1.4 to 1.3, and things with init-containers will still work (pods, deployments, etc). If you are running 1.3, only use the alpha annotation, or it may be lost when rolling forward. The status has moved from annotation key `pods.beta.kubernetes.io/init-container-statuses` to `pods.beta.kubernetes.io/init-container-statuses`. Any code that inspects this annotation should be changed to use the new key. State of Initialization will continue to be reported in both pods.alpha.kubernetes.io/initialized and in `podStatus.conditions.{status: "True", type: Initialized}` ``` Mini-design for this change: Goals: 1. A user can create an object with the beta annotation on 1.4, and it works. The fact that the annotation has beta in it communicates to the user that the feature is beta, and so the user should have confidence in using it. Preferably, when the user gets the annotation back, he see the beta annotation. 1) If someone had an existing alpha object in their apiserver, such as a RS with a pod template with an init-containers annotation on it, it should continue to work (init containers run) when stack upgraded to 1.4. 2) If someone is using a chart or blog post that has alpha annotation on it and they create it on a 1.4 cluster, it should work. 3) If someone had something with an init container in 1.4 and they roll back stack to 1.3, it should not silently stop working (init containers don't run anymore). To meet all these, we mirror an absent beta label from the alpha key and vice versa. If they are out of sync, we use the alpha one. We do this in conversion since there was already logic there. In 1.3 code, all annotations are preserved across a round trip (v1 -> api -> v1), and the alpha annotation turns into the internal field that kubelet uses. In 1.4 code, the alpha annotation is always preserved across a round trip, and a beta annotation is always set equal to the alpha one, after a round trip. Currently, the kubelet always sees the object after a round trip when it GETs it. But, we don't want to rely on that behavior, since it will break when fastpath is implemented. So, we rely on this: all objects either are created with an alpha annotation (1.3 or 1.4 code) or are created with a beta annotation under 1.4. In the later case, they are round tripped at creation time, and so get both annotations. So all subsequent GETs see both labels.
if valueBeta, okBeta := in.Annotations[PodInitContainersBetaAnnotationKey]; okBeta { | ||
in.Annotations[PodInitContainersAnnotationKey] = valueBeta | ||
} | ||
// Move the annotation to the internal repr. field |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: s/repr./representative?
When we talked yesterday, we only thought other way around by setting alpha one to beta after a round trip. But that has rollback issue. Your new way resolved that rollback issue and much conciser than the old one. Clever! LGTM |
I believe you already did upgrade test for this. :-) |
GCE e2e build/test passed for commit 6e5a7f9. |
Automatic merge from submit-queue |
Why are we using an annotation for beta? We say we preserve beta functionality over an upgrade - which means we have to support beta annotation -> final field. Why wouldn't we just add a field here? Also, please cc me on init container changes so I can review them in the future The way we are versioning annotations seems more and more arbitrary every time we apply it. |
// TODO: when we move init container to beta, remove these conversions | ||
// If there is a beta annotation, copy to alpha key. | ||
// See commit log for PR #31026 for why we do this. | ||
if valueBeta, okBeta := in.Annotations[PodInitContainersBetaAnnotationKey]; okBeta { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I really can't see how this provides value to end users. Why not drop the alpha annotation? Why do I need to support alpha and beta at the same time?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The value is that a user who learns about the feature knows how stable it is.
For example, on GKE, we don't typically expose users to alpha features, but we do expose beta ones.
@smarterclayton: /~https://github.com/kubernetes/kubernetes/blob/master/docs/devel/api_changes.md#alpha-beta-and-stable-versions says:
|
As far as I know, this it the first time an alpha annotation feature has moved to beta, so there is no precedent, right? |
There is no precedence. I was not aware that we weasel worded beta that Something we need to do for this is to add a release note instructing Here's the doc I wrote up for OpenShift 3.3 (where SCC policy was already On Mon, Aug 22, 2016 at 2:34 PM, Eric Tune notifications@github.com wrote:
|
The procedure you referenced appears to be solid for going 1.2 to 1.3. It cannot be used as is in a race-free manner for 1.3 to 1.4. Need to think about it a little more. |
Updated the relnote to reflect action required. |
Automatic merge from submit-queue Fix backward compatibility issue caused by promoting initcontainers f… #31026 moves init-container feature from alpha to beta, but only took care the backward compatibility for pod specification, not deal with status. For status, it simply moved from `pods.beta.kubernetes.io/init-container-statuses` to `pods.beta.kubernetes.io/init-container-statuses` instead of introducing one more pods.beta.kubernetes.io/init-container-statuses. This breaks when the cluster is running with 1.4, but the user is still running with kubectl 1.3.x. Fixed #32711
Mini-design for this change:
Goals:
on 1.4, and it works. The fact that the annotation has beta
in it communicates to the user that the feature is beta,
and so the user should have confidence in using it. Preferably,
when the user gets the annotation back, he see the beta
annotation.
such as a RS with a pod template with an init-containers
annotation on it, it should continue to work (init containers
run) when stack upgraded to 1.4.
annotation on it and they create it on a 1.4 cluster, it should
work.
and they roll back stack to 1.3, it should not silently stop
working (init containers don't run anymore).
To meet all these, we mirror an absent beta label from the alpha
key and vice versa. If they are out of sync, we use the alpha
one. We do this in conversion since there was already logic there.
In 1.3 code, all annotations are preserved across a round trip
(v1 -> api -> v1), and the alpha annotation turns into the internal
field that kubelet uses.
In 1.4 code, the alpha annotation is always preserved across
a round trip, and a beta annotation is always set equal to
the alpha one, after a round trip.
Currently, the kubelet always sees the object after a round trip
when it GETs it. But, we don't want to rely on that behavior,
since it will break when fastpath is implemented.
So, we rely on this:
all objects either are created with an alpha annotation (1.3 or 1.4
code) or are created with a beta annotation under 1.4. In the later
case, they are round tripped at creation time, and so get both
annotations. So all subsequent GETs see both labels.
This change isdata:image/s3,"s3://crabby-images/1ad2f/1ad2fd0bc0e698bd9222711c43b5ae362cb93e3f" alt="Reviewable"