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

Bug Report: /metrics - invalid prometheus format (HELP duplicates)/FISH-8522 #6596

Closed
rafi0101 opened this issue Mar 22, 2024 · 2 comments · Fixed by #6970
Closed

Bug Report: /metrics - invalid prometheus format (HELP duplicates)/FISH-8522 #6596

rafi0101 opened this issue Mar 22, 2024 · 2 comments · Fixed by #6970
Assignees
Labels
Status: Accepted Confirmed defect or accepted improvement to implement, issue has been escalated to Platform Dev Type: Bug Label issue as a bug defect

Comments

@rafi0101
Copy link

Brief Summary

if this sounds familiar to you, yes, I have oriented myself to this topic because it is almost the same error: #4579

The default /metrics endpoint returns duplicated HELP entries which does not comply with Prometheus text-based exposition format.
The specification under https://prometheus.io/docs/instrumenting/exposition_formats/#text-format-details says:

Only one HELP line may exist for any given metric name.

In my case Telegraf failed too:

2024-03-22T14:25:50Z E! [inputs.prometheus] Error in plugin: error reading metrics for "http://localhost:8080/metrics": decoding response failed: text format parsing error in line 176: second HELP line for metric name "gc_time_seconds_total"

We upgraded from payara 5.2022.3 to 6.2024.1 and this problem occours to all our Payara Servers and Payara Micros. Occurs with /base and /application metrics

Found this issues / pull requests but they didn't help me:
eclipse/microprofile-metrics#616
eclipse/microprofile-metrics#638
eclipse/microprofile-metrics#597

Maybe you can help me this this :)

Expected Outcome

payara 5.2022.3

# TYPE base_gc_time_total counter
# HELP base_gc_time_total Displays the approximate accumulated collection elapsed time in milliseconds. This attribute displays -1 if the collection elapsed time is undefined for this collector. The JVM implementation may use a high resolution timer to measure the elapsed time. This attribute may display the same value even if the collection count has been incremented if the collection elapsed time is very short.
base_gc_time_total{name="G1 Young Generation"} 817924
base_gc_time_total{name="G1 Old Generation"} 14374

# TYPE base_gc_total_total counter
# HELP base_gc_total_total Displays the total number of collections that have occurred. This attribute lists -1 if the collection count is undefined for this collector.
base_gc_total_total{name="G1 Young Generation"} 12002
base_gc_total_total{name="G1 Old Generation"} 33

Current Outcome

payara 6.2024.1 (Microprofile 6.1, Microprofile Metrics-API 5.1.0)

# TYPE gc_time_seconds_total counter
# HELP gc_time_seconds_total Displays the approximate accumulated collection elapsed time in milliseconds. This attribute displays -1 if the collection elapsed time is undefined for this collector. The JVM implementation may use a high resolution timer to measure the elapsed time. This attribute may display the same value even if the collection count has been incremented if the collection elapsed time is very short.
gc_time_seconds_total{mp_scope="base",name="G1 Young Generation"} 6.88
# HELP gc_time_seconds_total Displays the approximate accumulated collection elapsed time in milliseconds. This attribute displays -1 if the collection elapsed time is undefined for this collector. The JVM implementation may use a high resolution timer to measure the elapsed time. This attribute may display the same value even if the collection count has been incremented if the collection elapsed time is very short.
gc_time_seconds_total{mp_scope="base",name="G1 Old Generation"} 0.0

# TYPE gc_total counter
# HELP gc_total Displays the total number of collections that have occurred. This attribute lists -1 if the collection count is undefined for this collector.
gc_total{mp_scope="base",name="G1 Young Generation"} 102.0
# HELP gc_total Displays the total number of collections that have occurred. This attribute lists -1 if the collection count is undefined for this collector.
gc_total{mp_scope="base",name="G1 Old Generation"} 0.0

Reproducer

Operating System

Debian 11

JDK Version

openjdk-17-jre-headles

Payara Distribution

Payara Server Full Profile, Payara Micro

@rafi0101 rafi0101 added Status: Open Issue has been triaged by the front-line engineers and is being worked on verification Type: Bug Label issue as a bug defect labels Mar 22, 2024
@felixif
Copy link

felixif commented Apr 8, 2024

Hello @rafi0101,

I have verified the latest version of Payara and I can confirm that the issue is reproducible. The HELP section for gc_total and gt_time_seconds_total is duplicated. I have raised an internal issue, codename FISH-8522, and our developers will look into it as soon as they have the bandwidth. Thank you very much for your bug report!

Best regards,
Felix Ifrim

@felixif felixif changed the title Bug Report: /metrics - invalid prometheus format (HELP duplicates) Bug Report: /metrics - invalid prometheus format (HELP duplicates)/FISH-8522 Apr 8, 2024
@felixif felixif added Status: Accepted Confirmed defect or accepted improvement to implement, issue has been escalated to Platform Dev and removed Status: Open Issue has been triaged by the front-line engineers and is being worked on verification labels Apr 8, 2024
@fschuerer
Copy link

Hello,

with Payara version 6.2024.11, the HELP and TYPE duplicates have disappeared, but the values are still duplicated, leading to Prometheus errors.

For example:

# TYPE gc_total counter
# HELP gc_total Displays the total number of collections that have occurred. This attribute lists -1 if the collection count is undefined for this collector.
gc_total{mp_scope="base",name="G1 Young Generation"} 46.0
gc_total{mp_scope="base",name="G1 Old Generation"} 1.0
.
.
.
gc_total{mp_scope="base",name="G1 Young Generation"} 46.0
gc_total{mp_scope="base",name="G1 Old Generation"} 1.0

The duplicates are only present, when at least one method is annotated with a metric annotation (@counted e.g.).
When I use a scope filter (http://localhost:8080/metrics?scope=base), the duplicates are not displayed.

Best regards,
Frank

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Status: Accepted Confirmed defect or accepted improvement to implement, issue has been escalated to Platform Dev Type: Bug Label issue as a bug defect
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants