-
Notifications
You must be signed in to change notification settings - Fork 707
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
Set reasonable QPS/Burst for resources RESTMapper client #4370
Set reasonable QPS/Burst for resources RESTMapper client #4370
Conversation
DISCOVERY_CLIENT_QPS = 50.0 | ||
DISCOVERY_CLIENT_BURST = 100 |
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.
Good catch! Would it make sense to have them as environment variables, defaulted to those values if not present? Don't remember if we are using env variables for this kind of setup. I was thinking in the cases of environments where K8s resources are scarce (e.g. Docker desktop extension or small clusters).
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.
+1 to provide these vars externally. I mean, we're already passing QPS
and burst
in the chart, so it is just a matter of using it, no?
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.
Not quite. I did look at it, but it'll require changing the arguments of the grpc registration function. I (personally) don't see any need to be able to modify them, since unlike the user client, they're only used on startup when initializing the RESTMapper.
But I'm not against passing them through... it's just a matter of updating all the plugins to match. Happy to do so if you both think it's better.
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.
It might even be a chance to replace the (growing) args to the grpc registration function with a struct so that we don't need to update the function signature each time.
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.
It might even be a chance to replace the (growing) args to the grpc registration function with a struct so that we don't need to update the function signature each time.
+1, that would be nice and give flexibility to the registration process.
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.
OK, I've updated this PR, rebasing on #4372 so it's clear as an example how we can update the args to the plugin registration without having to modify other plugins necessarily. PTAL :)
Signed-off-by: Michael Nelson <minelson@vmware.com>
Signed-off-by: Michael Nelson <minelson@vmware.com>
Signed-off-by: Michael Nelson <minelson@vmware.com>
75fd3ce
to
2a3f661
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.
Great, thank you! I do like this approach rather than hardcoding the defaults as constants. Especially, when it comes to rate limitations. This way we ensure Kubeapps can be adjusted for fitting each cluster's performance needs.
ClientQPS float32 | ||
ClientBurst int |
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.
Ah, ok, so these values are already been set by the kube-api-qps
and kube-api-burst
CLI flags we added in the past, aren't they?
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.
Yes, if we're passing them in, I didn't see a reason to use different flags for this client than those already passed in for the user client, so populate the values from the existing flags.
Landed at #4386 |
Description of the change
Sets reasonable QPS and Burst for the client config used only in the discovery of the REST API (by the RESTMapper).
Before this change, registering the resources plugin took around 8 seconds due to client throttling:
With this change, it's under 500ms (with no warnings of throttling):
Benefits
Faster startup time for the kubeapps-apis server (see #4329).
Possible drawbacks
Initial hammer of the k8s API server when the rest mapper initialises, but don't see this as an issue.
Applicable issues
Additional information
I did investigate whether we could use the client-getter to create a client using the chart configured defaults, but the client-getter is very careful to restrict itself to user requests, enforcing a user token, ensuring any service account token from the service is not used, etc., which I do not think we should change. Given that this client is used only for generating the rest mapper, I ended up going for simple constants.