Skip to content
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

Fix strategic patch for list of primitive type with merge sementic #35647

Merged
merged 1 commit into from
Nov 11, 2016

Conversation

mengqiy
Copy link
Member

@mengqiy mengqiy commented Oct 26, 2016

Fix strategic patch for list of primitive type when the patch strategy is merge.
Before: we cannot replace or delete an item in a list of primitive, e.g. string, when the patch strategy is merge. It will always append new items to the list.
This patch will generate a map to update the list of primitive type.
The server with this patch will accept either a new patch or an old patch.
The client will found out the APIserver version before generate the patch.

Fixes #35163, #32398

cc: @pwittrock @fabianofranz

Fix strategic patch for list of primitive type when patch strategy is `merge` to remove deleted objects.

This change is Reviewable

@mengqiy
Copy link
Member Author

mengqiy commented Oct 26, 2016

This change will break the current tests, since part of the format of the format has changed.
I will fix them and add new tests when everyone is happy with the change.

@mengqiy
Copy link
Member Author

mengqiy commented Oct 26, 2016

Currently the old the client is able to talk to the new API server and the API server will behave the same when merging the patch.
But an old server will not accept a patch that generated by the new client. It will fail.
I can add some logic to let the kubectl get the API server version first before generating the patch to make the new client be able to talk to an old API server

@k8s-github-robot k8s-github-robot added kind/api-change Categorizes issue or PR as related to adding, removing, or otherwise changing an API size/L Denotes a PR that changes 100-499 lines, ignoring generated files. release-note-label-needed labels Oct 26, 2016
@mengqiy
Copy link
Member Author

mengqiy commented Oct 26, 2016

@k8s-bot ok to test

@pwittrock
Copy link
Member

@ymqytw Any idea why the tests failed?

@mengqiy
Copy link
Member Author

mengqiy commented Oct 27, 2016

I guess something went wrong with the test-infra, since I found many tests were failing because of IsUp or Up exit with status 1.

@pwittrock pwittrock assigned caesarxuchao and pwittrock and unassigned thockin Oct 27, 2016
@mengqiy mengqiy force-pushed the patch_primitive_list branch from fd8ff44 to 43a6d7a Compare October 28, 2016 06:48
@k8s-github-robot k8s-github-robot added size/XL Denotes a PR that changes 500-999 lines, ignoring generated files. and removed kind/api-change Categorizes issue or PR as related to adding, removing, or otherwise changing an API size/L Denotes a PR that changes 100-499 lines, ignoring generated files. labels Oct 28, 2016
@mengqiy
Copy link
Member Author

mengqiy commented Oct 28, 2016

@k8s-bot test this

@k8s-ci-robot
Copy link
Contributor

Jenkins Kubemark GCE e2e failed for commit 01f0aa0e47c14c387c6bf74b9cea98287b33d05a. Full PR test history.

The magic incantation to run this job again is @k8s-bot kubemark e2e test this. Please help us cut down flakes by linking to an open flake issue when you hit one in your PR.

@mengqiy mengqiy force-pushed the patch_primitive_list branch from 01f0aa0 to 14b5d7d Compare October 29, 2016 02:23
@k8s-ci-robot
Copy link
Contributor

Jenkins GCE e2e failed for commit 14b5d7d1d14d9d5c37f8d1de8c9802218a22b12e. Full PR test history.

The magic incantation to run this job again is @k8s-bot cvm gce e2e test this. Please help us cut down flakes by linking to an open flake issue when you hit one in your PR.

@mengqiy mengqiy changed the title Fix strategic patch for list of primitive type with merge sementic [WIP] Fix strategic patch for list of primitive type with merge sementic Oct 29, 2016
@k8s-github-robot k8s-github-robot added the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Oct 29, 2016
@pwittrock
Copy link
Member

@ymqytw Let me know if I should take a look again

@mengqiy mengqiy force-pushed the patch_primitive_list branch from 14b5d7d to 787f339 Compare October 31, 2016 22:30
@k8s-github-robot k8s-github-robot added size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files. and removed needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. size/XL Denotes a PR that changes 500-999 lines, ignoring generated files. labels Oct 31, 2016
@mengqiy
Copy link
Member Author

mengqiy commented Nov 16, 2016

@smarterclayton If we encounter error when calling GetServerSupportedSMPatchVersion(), it's safe to default to the old behavior as v1.4 which won't break any older server. But it will leave apply broken for list of primitives.
What is the solution?

@pwittrock
Copy link
Member

@smarterclayton WDYT of defaulting to the new patch version when we can't get the supported version from the server? Is it safe to require that all servers will support the same STMRG version? I am not sure if there is a perfect solution here and want to make sure we make a good set of tradeoffs.

@smarterclayton
Copy link
Contributor

I'm ok with defaulting to the latest (if we are broken with the old way).
Just need a default and not to error out.

On Wed, Nov 16, 2016 at 11:31 AM, Phillip Wittrock <notifications@github.com

wrote:

@smarterclayton https://github.com/smarterclayton WDYT of defaulting to
the new patch version when we can't get the supported version from the
server? Is it safe to require that all servers will support the same STMRG
version? I am not sure if there is a perfect solution here and want to make
sure we make a good set of tradeoffs.


You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
#35647 (comment),
or mute the thread
https://github.com/notifications/unsubscribe-auth/ABG_p1IoNhhmuu8Aj8gYUDNY3h7cRIp7ks5q-1odgaJpZM4KhlTL
.

k8s-github-robot pushed a commit that referenced this pull request Nov 19, 2016
…_fail

Automatic merge from submit-queue

Fix kubectl Stratigic Merge Patch compatibility

As @smarterclayton pointed out in [comment1](#35647 (review)) and [comment2](#35647 (review)) in PR #35647,
we cannot assume the API servers publish version and they shares the same version.

This PR removes all the calls of GetServerSupportedSMPatchVersion().
Change the behavior of `apply` and `edit` to:
Retrying with the old patch version, if the new version fails.
Default other usage of SMPatch to the new version, since they don't update list of primitives.

fixes #36916

cc: @pwittrock @smarterclayton
@bgrant0607
Copy link
Member

bgrant0607 commented Nov 22, 2016

@pwittrock @ymqytw Sorry I didn't think about this very hard before.

I don't like that the patch deviates from the schema of the resource. Among other things, that prevents us from using the schema validator on patches.

Was a parallel list considered instead?

Also, we need to update the existing SMP doc:
https://github.com/kubernetes/kubernetes/blob/master/docs/devel/api-conventions.md#strategic-merge-patch

And ideally we'd write a more complete user-facing version of that section.

Also, I didn't have time to read the whole discussion, but I don't think it's valid to base any functionality on the release version. For instance, it's not clear to me that every use of Kubernetes source code is going to report the same release info. If we agree that this is the case, we need to document it in the api conventions.

cc @smarterclayton

@mengqiy
Copy link
Member Author

mengqiy commented Nov 22, 2016

I don't think it's valid to base any functionality on the release version.

@bgrant0607 This part has been removed in #36916. In that PR, we change the behavior to:
first try the new patch, if it fails because the server don't recognize it, it will try the old patch.

@bgrant0607
Copy link
Member

Thanks @ymqytw.

Also, mergeprimitiveslist deviates from our API conventions -- everything else in the API is camelCase or CamelCase. Since the other directives are lowercase, I'd expect mergePrimitivesList.

However, if we changed to parallel lists, we'd replace mergeprimitiveslist. For example, to delete one list entry from this:

finalizers: [ "A", "B", "C" ]

We could write something like:

"$deleteFromStringList/finalizers": ["C"]

@pwittrock
Copy link
Member

This makes sense to me @ymqytw given that the 1.5 cut date is fast approaching, what is your confidence that we could change the implementation to match @bgrant0607 's suggestion before the deadline?

@mengqiy
Copy link
Member Author

mengqiy commented Nov 23, 2016

@pwittrock I can try to create a PR for review before thanksgiving.

@pwittrock
Copy link
Member

Sounds good. Otherwise we may need to consider rolling back the client changes.

@bgrant0607
Copy link
Member

@pwittrock Is there a reason why we can't just rollback and try again in 1.6? What's blocked by this?

@bgrant0607
Copy link
Member

With my proposed approach, I believe older apiservers would just ignore the additional directives, though we should confirm that is true.

@bgrant0607
Copy link
Member

@ymqytw @pwittrock Please email sig-api-machinery to give them the opportunity to chime in before we merge the new approach.

@pwittrock
Copy link
Member

@bgrant0607 Nothing is blocked by this. The finalizers field in ObjectMeta were changed to use the a merge strategy, so this would be newly broken in 1.5. @caesarxuchao, I believe that you indicated that this was acceptable for 1.5 - would you confirm? If that is the case, rolling back the changes SGTM.

@caesarxuchao
Copy link
Member

Rolling back is fine. The garbage collector does NOT use patch to update the finalizers.

@mengqiy
Copy link
Member Author

mengqiy commented Nov 23, 2016

@pwittrock I think we should try the new way in 1.6. It may be too risky to do that for 1.5. Since there is only 1 week left, because of the Thanksgiving holiday.
I'm reverting these PR now.

@pwittrock
Copy link
Member

Agreed

@mengqiy
Copy link
Member Author

mengqiy commented Nov 23, 2016

Reverting related PRs in #37343.

@lavalamp
Copy link
Member

Not that we should necessarily copy them, but mongo does it this way: https://docs.mongodb.com/manual/reference/operator/update/pull/

(I think 'pull' is a silly name for this.)

I do think $deleteFromStringList is overly specific, though. Perhaps 'primitive' instead of string?

@mengqiy
Copy link
Member Author

mengqiy commented Nov 30, 2016

@lavalamp I created a design doc PR #37652 for this. PTAL

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
lgtm "Looks good to me", indicates that a PR is ready to be merged. release-note Denotes a PR that will be considered when it comes time to generate release notes. size/XXL Denotes a PR that changes 1000+ lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.