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

Add matcher based tenancy to api/v1/rules #204

Merged
merged 1 commit into from
Feb 7, 2022

Conversation

saswatamcode
Copy link
Member

@saswatamcode saswatamcode commented Jan 17, 2022

Currently, a call to the /api/metrics/v1/{tenant}/api/v1/rules endpoint, returns rules for all tenants, as it proxies the request to Thanos Querier.

This PR adds tenant isolation to /api/metrics/v1/{tenant}/api/v1/rules endpoint, by adapting prom-label-proxy code to modify the API response from the Thanos Query api/v1/rules endpoint and filter via the tenant label (this is possible as we enforce tenant labels on rules). So each tenant can only retrieve their own rules.

Relevant issue: https://issues.redhat.com/browse/MON-2141

@squat
Copy link
Member

squat commented Jan 17, 2022

Hey @saswatamcode, regarding:

a call to the /api/metrics/v1/{tenant}/api/v1/rules endpoint, returns rules for all tenants

I don't quite agree with this statement. I think the ticket that you linked in the PR description is incorrect. The rules API is already tenant-aware: the /rules API is filtering results so that we only get the rules that were defined by one single tenant. Furthermore, the client must be authorized to read metrics from the specified tenant in order to fetch the rules. Please look here:

resp, err := rh.client.ListRules(r.Context(), tenant)

However, as I mentioned in #191

Note: this is a distinct problem from ensuring that the rules written by
a tenant are guaranteed to only include data from that tenant.
Currently, the rules from a tenant can select data from any tenant. This
is a distinct problem and should absolutely be tackled in a follow up.

I think this is the problem you, and the Jira ticket, are trying to address?

@saswatamcode
Copy link
Member Author

saswatamcode commented Jan 17, 2022

Hi @squat! :)
Yes, the naming is a bit confusing, as both deal with rules, but let me clarify the purpose of this ticket/PR,

  • Currently, the rules API which hits the Rules storage backend is tenant-aware. A tenant can get and set rules in YAML format, via GET and PUT requests to the api/metrics/v1/{tenant}/api/v1/rules/raw endpoint of the API.
  • However when a tenant sends a GET request to api/metrics/v1/{tenant}/api/v1/rules, the request is proxied by the API to the read upstream endpoint (for eg. Thanos Querier). The querier sends back all rules of all tenants in JSON. This is handled using uiProxy. This is what this ticket/PR aims to solve.

Maybe I should change the PR title?

Note: this is a distinct problem from ensuring that the rules written by
a tenant are guaranteed to only include data from that tenant.
Currently, the rules from a tenant can select data from any tenant. This
is a distinct problem and should absolutely be tackled in a follow up.

This is still a distinct problem. :)

@squat
Copy link
Member

squat commented Jan 17, 2022

ack. I wasn't aware of this second endpoint. hmm this endpoint seems to be essentially part of an attempt trying to turn Observatorium into an equivalent Prometheus/Thanos Querier replacement

@bill3tt
Copy link

bill3tt commented Jan 18, 2022

Nice PR @saswatamcode ✊ I think the changes you have proposed would work, but I am wondering if there is a different solution that better maintains existing properties of the API 🤔

As @squat alludes to - the API was always designed and intended to be a light-weight authentication and authorization proxy that enforced the relevant tenant configurations on requests. With this in mind, it feels like adding rule specific logic in this PR start to take us down a path we have tried our best to resist so far!

Did you consider any upstream / Thanos first approaches? For example if the Thanos Query rules API supported matchers (like /labels does), then the API would then append the right labels and proxy the request forward.

This would be more work (requires change in Rules proto), but feels like it would maintain the lightweight API properties and could also be useful for Thanos.

@saswatamcode
Copy link
Member Author

Hi @ianbillett!
Yes, I did consider the upstream first approach before, while discussing this with @onprem. 🙂

Adding matcher support to Thanos Query rules API is certainly possible but I was a bit hesitant to go with that, as this would make the Query rules API diverge from the Prometheus rules API (one would have matcher support while the other wouldn't).

Also, I found precedent that bits of prom-label-proxy were already adapted in Observatorium API here, so I decided to go with this.

If the upstream approach seems better for this use case, I can raise a PR to Thanos and update this PR once merged. WDYT? 🙂

@bwplotka
Copy link
Member

SGTM for changing Prom and Thanos API first (:

Sounds like this is a great starting point: prometheus/prometheus#9627

@bill3tt
Copy link

bill3tt commented Jan 20, 2022

We just discussed this issue at the Thanos Community hours meeting 👍

We're happy with the idea of adding matchers to the Thanos /rules calls. Though this would make Thanos differ from the Prometheus API that is ok, as long as all valid Prometheus requests are still compatible. In fact, there is an upstream Prometheus issue prometheus/prometheus#9627 that is proposing the same thing.

Next steps are to follow up with the upstream issue first, and if we can't progress with that then add it in Thanos 👍

edit: @bwplotka beat me to the summary 😅

@squat
Copy link
Member

squat commented Jan 20, 2022

one thing I'm curious about is why we want to add this as a first-class feature in the Thanos/Prometheus API vs making the prom-label proxy part of the Observatorium infrastructure/deployment and add the enforcement there?

Signed-off-by: Saswata Mukherjee <saswataminsta@yahoo.com>
@saswatamcode
Copy link
Member Author

I think adding this as a first-class feature to Thanos/Prometheus API would be better as it solves a couple of issues, 🙂

  • There are already issues asking for label-based matcher support in rules API upstream
  • By adding it here, we avoid having another moving part in our deployment but don't compromise on tenancy

@saswatamcode saswatamcode changed the title Add tenant-based filtering for Rules API response Add matcher based tenancy to api/v1/rules Feb 1, 2022
@saswatamcode
Copy link
Member Author

This can be merged once thanos#5111 makes its way to main! 🙂

Copy link
Contributor

@matej-g matej-g left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good, thank you @saswatamcode 👍

@matej-g matej-g merged commit b08584e into observatorium:main Feb 7, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants