-
Notifications
You must be signed in to change notification settings - Fork 17
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
Client should handle 502 errors #37
Comments
Hey, thank you for bringing this to our attention. We will raise it internally and get back to you with a response from the team. In the meantime, can you provide us with some additional information to help reproduce it:
|
Upon investigation, the conditions for this error being returned does indeed depend on non-Unleash software: The Unleash server was hosted on a Kubernetes cluster behind a Google load balancer. The server was being CPU-throttled and the load balancer returned the 502 message when it couldn't get a reply from Unleash. Still, it might be good to have some better handling of server errors. |
Hey, @skairunner 👋🏼 Thanks again for raising this! Let me just make sure I get this right:
Are those points correct? We've talked briefly about this internally, and I think the reason it works the way it does is intentional. There's not much the SDK can do if it receives an error response, and it'll try again after the specified refresh interval anyway. In cases where you need to get updates immediately, you're probably best off bumping up the refresh rate. Does that sound reasonable to you?
That's a fair point! What would you classify as "better handling" in this case? What would you expect? |
After learning that it was not an Unleash server thing but rather from the load balancer, I think my ticket might be fine being closed 😅 If it was inherently part of the unleash api then the client definitely would need to handle it, but since it's not... The client doesn't currently log the 502 error at all: it simply says Please feel free to close this issue! |
Got it! In that case I'll close this for now |
Describe the bug
The unleash server can return the following error when polling for features (
poll_for_update()
):The client currently naively tries to convert the returned body into json, fails, then dumps the error and proceeds as if an unrecoverable error happened, by not updating the features until the next poll interval/
This should be easily fixable by inspecting the response's status code and reacting to a 502, before converting it into a json.
Steps to reproduce the bug
Unfortunately I am unsure as to how to reproduce the error, as it may have something to do with specific server configurations or even the environment. However, it might be possible to mock the response from the server.
Expected behavior
Unleash client should probably retry the request as said by the server.
Logs, error output, etc.
No response
Screenshots
No response
Additional context
No response
Unleash version
Client: 0.6.1 alpha
Server: 3.17.6
Subscription type
Open source
Hosting type
Self-hosted
SDK information (language and version)
No response
The text was updated successfully, but these errors were encountered: