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

Rule formatting tool. #21

Open
juliusv opened this issue Jan 4, 2013 · 41 comments
Open

Rule formatting tool. #21

juliusv opened this issue Jan 4, 2013 · 41 comments

Comments

@juliusv
Copy link
Member

juliusv commented Jan 4, 2013

Like "gofmt" for Go, we ought to have a "promfmt" for Prometheus since we have a syntax tree. The idea being that the system produces uniform style that minimizes deviation and learning curve.

Update after we have totally moved to YAML rule files: In addition to formatting the PromQL expressions, we also want to format the YAML files to have a fixed structure, while preserving comments for both PromQL expressions and the YAML file.

matttproud added a commit that referenced this issue Apr 9, 2014
…nation

Support Protocol Buffer Message Decoding
@grobie
Copy link
Member

grobie commented Jun 23, 2015

👍 * 💯

@fabxc
Copy link
Contributor

fabxc commented Jun 24, 2015

Yep, that'd be great. Preserving comments is the biggest (and basically only) problem. And agreement on how to split expressions over multiple lines.

@brian-brazil
Copy link
Contributor

Aren't we in the middle of adding this to promtool?

@mattbostock
Copy link
Contributor

Related: #1779

simonpasquier pushed a commit to simonpasquier/prometheus that referenced this issue Oct 12, 2017
Use a protocol-relative URL to load Google Fonts
bobmshannon pushed a commit to bobmshannon/prometheus that referenced this issue Nov 19, 2018
pgier pushed a commit to pgier/prometheus that referenced this issue Jan 23, 2019
…r-promu

Install promu package for OCP multistage builds
@beorn7
Copy link
Member

beorn7 commented Mar 16, 2019

Some observations:

  • With the 2.x rule format (YAML embedding PromQL), we want this to act on YAML files, too.
  • It should preserve both comments in YAML and in PromQL.
  • Indentation is crucial (not just line breaks).
  • It has to be seen if certain line breaks in the input should be preserved in the output (cf. how gofmt does it).
  • Wherever a rule is rendered, the same formatting should apply, in particular on the Alerts and Rules tabs of the Prometheus web UI. This implies that the AST needs to keep comments (and possibly certain line breaks, see previous point).

@brian-brazil
Copy link
Contributor

It should preserve both comments in YAML

Our current YAML library doesn't do this, but is hoping to "soon".

@geekodour
Copy link
Contributor

I'd like to include this in my gsoc proposal. @brian-brazil, can you link to the YAML library you're referring to?

@brian-brazil
Copy link
Contributor

https://github.com/go-yaml/yaml, but I'd scope this to just the PromQL as this stands.

@juliusv
Copy link
Member Author

juliusv commented Mar 20, 2019

@brian-brazil But since the PromQL from rules is always embedded in YAML files, it at least has to preserve YAML comments, right? Otherwise the tool wouldn't be very useful as nobody wants to lose their comments the benefit of formatting.

@brian-brazil
Copy link
Contributor

That'd be nice, but we can get benefits without that. I'd rather also not depend on something with an unclear timeline for a gsoc project.

@beorn7
Copy link
Member

beorn7 commented Mar 21, 2019

Let's start with the PromQL part. The YAML part should be almost trivial once the library preserves comments and things like the |2 indentation hint for multiline strings.

@juliusv
Copy link
Member Author

juliusv commented Mar 21, 2019

Ok!

@brian-brazil
Copy link
Contributor

v3 of the YAML library is out, which should allow for all of this.

@sylr
Copy link
Contributor

sylr commented Apr 24, 2019

FYI perfectly readable rule in configuration

(
    kube_job_status_failed > 0
    UNLESS kube_job_status_succeeded > 0
)
* on (namespace, job_name) group_left(maintainer) label_replace(kube_job_labels, "maintainer", "$1", "label_maintainer", "(.*)")
* on (namespace, job_name) group_left(pager) label_replace(kube_job_labels, "pager", "$1", "label_pager", "(.*)")
* on (namespace, job_name) group_left(paging) label_replace(kube_job_labels, "paging", "$1", "label_paging", "(.*)")

VS its garbage representation in the Web UI

(kube_deployment_status_replicas_available
  / kube_deployment_spec_replicas * 100) * on(namespace, deployment) group_left(maintainer)
  label_replace(kube_deployment_labels, "maintainer", "$1", "label_maintainer",
  "(.*)") * on(namespace, deployment) group_left(pager) label_replace(kube_deployment_labels,
  "pager", "$1", "label_pager", "(.*)") * on(namespace,
  deployment) group_left(paging) label_replace(kube_deployment_labels, "paging",
  "$1", "label_paging", "(.*)") < 100

@geekodour
Copy link
Contributor

@sylr I think you posted some other rule from the web UI. also @beorn7 I am starting to work on this issue.

here's what it shows for me for your rule:

(kube_job_status_failed
  > 0 unless kube_job_status_succeeded > 0) * on(namespace, job_name) group_left(maintainer)
  label_replace(kube_job_labels, "maintainer", "$1", "label_maintainer",
  "(.*)") * on(namespace, job_name) group_left(pager) label_replace(kube_job_labels,
  "pager", "$1", "label_pager", "(.*)") * on(namespace,
  job_name) group_left(paging) label_replace(kube_job_labels, "paging", "$1",
  "label_paging", "(.*)")

@sylr
Copy link
Contributor

sylr commented May 28, 2019

@geekodour Yes, I mixed up two rules.

@slrtbtfs
Copy link
Contributor

@haibeey There already has been some progress in that direction.

When building such a formatter it probably would be best to start with what is already implemented here and add proper white space and comment handling.

It would be also nice, when such features could be integrated with the upcoming PromQL language server. Inside the language server code a lot of the stuff that is needed to format YAML files is already implemented, and it might make sense to reuse some of it.

@haibeey
Copy link
Contributor

haibeey commented Feb 17, 2020

alright! Thanks @slrtbtfs . i will start perusing the links shared ASAP .

@Harkishen-Singh
Copy link
Contributor

Can I take up this issue? Would love to implement this.

@roidelapluie
Copy link
Member

It looks like @haibeey is already somehow planning working on this.

@Harkishen-Singh
Copy link
Contributor

@roidelapluie I have already implemented a part of it way before. It's just that I had not mentioned here.

@haibeey
Copy link
Contributor

haibeey commented Mar 14, 2020

FYI perfectly readable rule in configuration

(
    kube_job_status_failed > 0
    UNLESS kube_job_status_succeeded > 0
)
* on (namespace, job_name) group_left(maintainer) label_replace(kube_job_labels, "maintainer", "$1", "label_maintainer", "(.*)")
* on (namespace, job_name) group_left(pager) label_replace(kube_job_labels, "pager", "$1", "label_pager", "(.*)")
* on (namespace, job_name) group_left(paging) label_replace(kube_job_labels, "paging", "$1", "label_paging", "(.*)")

VS its garbage representation in the Web UI

(kube_deployment_status_replicas_available
  / kube_deployment_spec_replicas * 100) * on(namespace, deployment) group_left(maintainer)
  label_replace(kube_deployment_labels, "maintainer", "$1", "label_maintainer",
  "(.*)") * on(namespace, deployment) group_left(pager) label_replace(kube_deployment_labels,
  "pager", "$1", "label_pager", "(.*)") * on(namespace,
  deployment) group_left(paging) label_replace(kube_deployment_labels, "paging",
  "$1", "label_paging", "(.*)") < 100

Is this formatting style acceptable? @codesome @juliusv @brian-brazil @beorn7
I'm writing my proposal based on this style.

@codesome
Copy link
Member

The final representation after formatting can be discussed and decided during the GSoC period (maybe even now if any maintainer wants to chime in, but I don't have the bandwidth to review it at the moment). I would suggest (to all GSoC aspirants) to focus on how would you achieve this.

@brian-brazil
Copy link
Contributor

https://prometheus.io/docs/practices/rules/ uses the best practices.

@haibeey
Copy link
Contributor

haibeey commented Mar 26, 2020

i wrote a rough prototype to preserve comments by augmenting the goyacc grammar rules a little. commit here haibeey@8855667

Rules file
recording rule in web ui

@brian-brazil
Copy link
Contributor

That doesn't look right, the operators aren't on their own line

@haibeey
Copy link
Contributor

haibeey commented Mar 26, 2020

oh yes. that commit doesn't do formmating. it is just to preserve comments in promql expr after evaluation for printing.
previous versions ignores all comments after evaluation.

@slrtbtfs
Copy link
Contributor

i wrote a rough prototype to preserve comments by augmenting the goyacc grammar rules a little. commit here [haibeey/prometheus@8855667]

Putting the comments in the AST seems like a reasonable idea.

I've left some comments about the implementation there.

@sylr
Copy link
Contributor

sylr commented Mar 26, 2020

https://prometheus.io/docs/practices/rules/ uses the best practices.

Please don't enforce:

sum without (instance)(instance_path:requests:rate5m{job="myjob"})

over

sum(instance_path:requests:rate5m{job="myjob"}) without (instance)

@brian-brazil
Copy link
Contributor

Having grouping modifiers first is the best practice, and is already how we print it - it's very difficult to read non-trivial expressions otherwise.

@juliusv
Copy link
Member Author

juliusv commented Mar 26, 2020

Yeah, I had strong opinions about this initially. At first Prometheus only supported sum(x) by(y) because it read more like English to me and thus I much preferred it, but for any non-trivial x it becomes really hard to see what dimensions you are aggregating over / keeping. I wish I had just made it sum by(y) (x) from the beginning and made that the only legal variant.

I still don't like at all the exact formatting sum by (y)(x) and much prefer sum by(y) (x) (makes much more sense to me), not sure why we chose to go for the latter one in the docs.

@sylr
Copy link
Contributor

sylr commented Mar 26, 2020

I think everyone is entitled to its own opinion about this, I personally find the "best practice" to be hideous, but, as all syntaxes are legal, please do not enforce one over the others.

@beorn7
Copy link
Member

beorn7 commented Mar 26, 2020

The whole point of a promfmt tool is to, if not enforce, at least "endorse" a certain "canonical" formatting, very much like gofmt, with a whole string of arguments behind it.

@juliusv
Copy link
Member Author

juliusv commented Mar 26, 2020

Yeah, gofmt's formatting is nobody's favorite, but at least it creates one consistent style rather than many different ones, which is a value in itself.

@codesome
Copy link
Member

As a side note, this is actively been sought after for the GSoC. @haibeey I see that you are also interested in GSoC. While I appreciate the upfront work that you have put now, I would appreciate some open discussions and design sharing, in the GSoC proposal or otherwise, for easier coordination of projects in GSoC :)

@Harkishen-Singh
Copy link
Contributor

Harkishen-Singh commented Mar 26, 2020

Comment preserving is already supported very well in the new go-yamlv3 library. The implementation is so flawless that there is no loss of comments. Hence, we can keep preserving mechanism independent from the Prometheus code without any worries.

@haibeey
Copy link
Contributor

haibeey commented Mar 26, 2020

alright. i guess it is time share my proposal draft GSoC proposal .

Reviews would be appreciated before the final draft. Thanks

@juliusv
Copy link
Member Author

juliusv commented Mar 26, 2020

@Harkishen-Singh There are two levels of comments: YAML comments and comments within a PromQL expression. #21 (comment) was talking about the PromQL ones (but YAML ones would be good to preserve as well).

@haibeey
Copy link
Contributor

haibeey commented Mar 26, 2020

Comment preserving is already supported very well in the new go-yamlv3 library. The implementation is so flawless that there is no loss of comments. Hence, we can keep preserving mechanism independent from the Prometheus code without any worries.

During evaluation of a PromQL expression is when the comments are removed.
That said i think the formatting is not only to be done in rules files but in some places too like the web ui. is this true @juliusv ?
So as pointed out by @slrtbtfs most of the formatting and preserving would be done in the Printer module.

@brian-brazil
Copy link
Contributor

In relation to YAML comments, there's problems with v3 that's causing issues for Cortex so we should avoid further rollout of that until that's all resolved.

That said i think the formatting is not only to be done in rules files but in some places too like the web ui. is this true

The web ui is the only place it's done.

replay pushed a commit to replay/prometheus that referenced this issue Jan 10, 2022
…ethod-in-new-postings-cloner

Use `ExpandPostings()` in `NewPostingsCloner()`
krya-kryak referenced this issue in krya-kryak/prometheus Mar 4, 2022
Add generatorURL to Alert struct
saswatamcode pushed a commit to saswatamcode/prometheus that referenced this issue Jun 17, 2024
…nt-version-2.6

[release-2.6] Added project component version
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet