-
Notifications
You must be signed in to change notification settings - Fork 2.5k
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
feat/re-allow multiple workers #36134
Conversation
I'll be OOO for the next few weeks, so I won't be able to review until then. |
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.
Thanks for the PR @bmiguel-teixeira! The contributions sound solid, but I'm a bit concerned that we're doing two separate things in one single PR here. Generally that's not a good practice because in case we have to revert one thing, we end up reverting more than what's needed, not to mention that it makes the PR biggers and a bit harder to review
Could you choose only one new functionality for this PR and open another one for the other?
Regarding the changes, could you add tests for the telemetry added? Send PRW requests to a mock server and assert that the metric you've added increments as you expected.
For allowing multiple workers, it would be nice if we add extra documentation making it clear that Out-of-order needs to be enabled in Prometheus for it to work :)
Sure. I will open a dedicated PR with the additional telemetry and keep de queue changes in this one which already has context. |
422bb46
to
2498ea3
Compare
hi @ArthurSens Removed the additional telemetry to be added in a secondary PR. Also added a bit of docs to explain the toggle and use case. Please take a look Cheers |
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.
Well, the code is simple so it does LGTM, but I'm struggling to test this.
Do you have any examples of apps/configs that will generate out of order datapoints? All attempts I've tried provide things in order so I can't be sure if this is working as expected 😅
(there's a linting failure) |
Hi @ArthurSens Just submitted your recomendation to fix the spelling issues. In regards to testing and simulating locally the out of order issues. Prometheus Config
Otel Config
Scenario 1: (Vanilla)
Outcome: Metrics are reingested, in order with single worker, ALL GOOD. Scenario 2 (PrometheusRemoteWrite 5 Consumers + Vanilla Prometheus)
Outcome: OutOfOrder Errors in Prometheus after boot up, since samples will be re-tried with no specific order. Scenario 3 (PrometheusRemoteWrite 5 Consumers + Prometheus with OutOfOrder Window)
Outcome: No OutOfOrder issues because even though we have multiple workers, Prometheus can accept mixed/old samples and update tsdb until 10 minutes "ago". Let me know if you need any more info. Cheers. |
2978d8c
to
012fe5d
Compare
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.
Perfect; thank you for the instructions! I just tested it, and it works perfectly. There's just one CI failure that we need to fix before approving here.
Could you run make generate
and commit the changes?
2a50228
to
7c25326
Compare
@ArthurSens All done! |
3a2ac49
to
38d7bcc
Compare
Hey @bmiguel-teixeira, once #36601 is merged, I think we should be safe to proceed with multiple workers again :) Could you rebase your PR on top of main once that happens? |
Hi @ArthurSens No worries on the delays. If Then we have feature gate for controlling the parallelism. If the gate is absent, we keep the default behaviour with single worker thread and with Hopefully this helps |
func toPtr[T any](val T) *T { | ||
ret := val | ||
return &ret | ||
} |
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.
Go is pass by copy, so it is fine to take the address of the val
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.
ur right. updated.
Looks like the linter is not happy /~https://github.com/open-telemetry/opentelemetry-collector-contrib/actions/runs/12754053453/job/35549100453?pr=36134:
EDIT: I missed that the linter is not introduced by this PR. The linter issue should be fixed in #37177. |
Please rebase |
please fix |
afe3f33
to
1dd2fd6
Compare
1dd2fd6
to
ce1d15a
Compare
d97806f
to
8dc53f4
Compare
NVM, the errors in code owners are from #37279 this PR should be good |
@songy23 let me know if anything else is needed. Cheers |
Description
This MR does the following:
Out of Order is no longer an issue now that it is fully supported in Prometheus. Nonetheless, I am setting the default worker as 1 to avoid OoO in Vanilla Prometheus Settings.
With a single worker, and for a collector with a large load, this becomes "blocking". Example: Imagine a scenario in which a collector is collecting lots of targets, and with a slow prometheus/unstable network, a single worker can easily bottleneck the off-shipping if retries are enabled.
Link to tracking issue
N/A
Testing
Documentation
docs auto-updated. Readme.md is now correct in its explanation of the `num_consumers since its no longer hard-coded at 1. Additional docs added.