-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
Namespaces included by labelSelector act as IncludedNamespaces for Backup #8342
base: main
Are you sure you want to change the base?
Conversation
25e190c
to
d311933
Compare
5e2355e
to
f2f044b
Compare
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #8342 +/- ##
==========================================
- Coverage 58.99% 58.99% -0.01%
==========================================
Files 367 367
Lines 38847 38870 +23
==========================================
+ Hits 22918 22931 +13
- Misses 14467 14475 +8
- Partials 1462 1464 +2 ☔ View full report in Codecov by Sentry. |
every item under NS is included. Signed-off-by: Tiger Kaovilai <[email protected]>
I understand there is a requirement from the community to back up resources under the labelled namespace, but we can also do that by using the namespace filter, do we need a new way to do the same function? |
Some admins may find it easier to automate ns backup by label. Apart from velero issue this pr fixes, it has also been requested to our team in https://issues.redhat.com/browse/OADP-4572 I think the question is, when is the current behavior of backing up namespace but not namespaced resources within it desirable? The previous fix already decided that any namespace not included by namespace filters like label should not be in the backup. Now we're just saying every namespace included via namespace filters (including label) will have namespaced resources of those namespaces in the backup. |
@kaovilai Thanks for this PR, but have we reached agreement in terms of whether we should implement it? |
I don't think we have reached agreements yet. |
@kaovilai I agree that only backing up the namespace with selected labels without any resources in it is not a common use case, but at least, we have that option. After introducing this change, we lost that option. If the introduced method is the preferable option, we can go forward that way, but before applying it, I think we need to make sure that. |
Another thing with this implementation is that namespaces included via label selector would not show up in |
@kaovilai v1.16 candidate? |
Please add this PR to v1.16 milestone |
# Individual objects must match this label selector to be included in the backup. Optional. | ||
# Individual objects must match this label selector to be included in the backup. | ||
# If matched object is Namespace, the namespace will act as IncludedNamespaces, and all resources in the namespace are included in the backup. | ||
# Optional. | ||
labelSelector: |
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.
should the CRD description be updated?
velero/pkg/apis/velero/v1/backup_types.go
Lines 88 to 90 in dce9777
// LabelSelector is a metav1.LabelSelector to filter with | |
// when adding individual objects to the backup. If empty | |
// or nil, all objects are included. Optional. |
@@ -594,7 +627,8 @@ func sortCoreGroup(group *metav1.APIResourceList) { | |||
// pod is backed up, we can perform a pre hook, then process pvcs and pvs (including taking a |
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.
need to update doc comment?
Thank you for contributing to Velero!
Please add a summary of your change
Namespaces included by backup's selector behave the same as specifying backup.IncludedNamespaces. All resources under the labeled namespace is included.
Prior to this change, labeled namespaces are included, but anything else under the namespace if not labeled are not.
Does your change fix a particular issue?
Fixes #7492
Please indicate you've done the following:
make new-changelog
) or comment/kind changelog-not-required
on this PR.site/content/docs/main
.