-
Notifications
You must be signed in to change notification settings - Fork 809
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
Ruler Object Storage Base64 Encoding #2646
Ruler Object Storage Base64 Encoding #2646
Conversation
Signed-off-by: Jacob Lisi <jacob.t.lisi@gmail.com>
The code looks good so I have approved, but there's more to consider here. Depending on how you look at it, this could be considered a breaking change and/or a bugfix. I think we might need to support both lookup methods (whilst all new writing should be done under the new method) in the meantime and deprecate eventually on Cortex 1.4 (I have seen that version number used around, so I think there are some cadence rules around deprecation/breaking changes). With that said, I understand there's migration tooling in the work to aid Cortex users on migrating to the new format. Perhaps that could help accelerate the deprecation process? We probably need @pracucci or @pstibrany input here. |
You're are correct that it's both a bug fix and a breaking change. However, the ruler API and the underlying object storage implementation is experimental. Our V1 Guarantees are very clear this feature is subject to breaking changes. IMO, the best we can do is communicate this change clearly in the Change Log and we can provide resources for a migration. I don't think it makes sense to support both methods since anyone who uses the old method will be using an implementation that is broken by design. Currently the number of users exposed to this feature is relatively small and it is better to make the transition now rather than wait until more users are affected. |
@jtlisi You're 100% correct. It is clearly listed under the experimental features - I take my comment back. I'm good with this 👍 |
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 understand the need of doing this fix. LGTM 👍
Please remind to explain the change in the CHANGELOG.
*Note: This is a breaking change for anyone with the -experimental.ruler.enable-api enabled and object storage configured. I am working on a small migration tool w/ docs for anyone in this predicament.
That would be great, but not strictly required IMO, considering it's an experimental feature (unless you will build it anyway for other reasons, like your own usage). But at least should be clearly stated in the CHANGELOG.
)" This reverts commit 44d2724.
What this PR does:
This PR incorporates a small aspect of the #2543 that ensures rule group names and namespaces are base64 encoded when incorporated into the object key and written to disk. This fixes an issue where illegal characters such as
/
can be set in a rule group that affects the proper operation of the system. This can be seen by running the current integration test present in this PR against a current version of Cortex.Base64 Encoding was chosen since it is a universally accepted format and fulfills all the naming requirements of common object storage backends:
*Note: This is a breaking change for anyone with the
-experimental.ruler.enable-api
enabled and object storage configured. I am working on a small migration tool w/ docs for anyone in this predicament.Checklist
CHANGELOG.md
updated - the order of entries should be[CHANGE]
,[FEATURE]
,[ENHANCEMENT]
,[BUGFIX]