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

Client should handle 502 errors #37

Closed
skairunner opened this issue Jun 14, 2022 · 5 comments
Closed

Client should handle 502 errors #37

skairunner opened this issue Jun 14, 2022 · 5 comments
Assignees
Labels
bug Something isn't working

Comments

@skairunner
Copy link

skairunner commented Jun 14, 2022

Describe the bug

The unleash server can return the following error when polling for features (poll_for_update()):

\n<html><head>\n<meta http-equiv=\"content-type\" content=\"text/html;charset=utf-8\">\n<title>502 Server Error</title>\n</head>\n<body text=#000000 bgcolor=#ffffff>\n<h1>Error: Server Error</h1>\n<h2>The server encountered a temporary error and could not complete your request.<p>Please try again in 30 seconds.</h2>\n<h2></h2>\n</body></html>\n

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

@skairunner skairunner added the bug Something isn't working label Jun 14, 2022
@andreas-unleash
Copy link

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:

  • Server configuration
  • Environmant configuration

@skairunner
Copy link
Author

skairunner commented Jun 15, 2022

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.

@thomasheartman thomasheartman moved this from New to Todo in Issues and PRs Jun 16, 2022
@thomasheartman thomasheartman self-assigned this Jun 16, 2022
@thomasheartman
Copy link
Contributor

Hey, @skairunner 👋🏼

Thanks again for raising this! Let me just make sure I get this right:

  • When the client receives a 502 response, it logs an error, then continues running. It will try fetching toggles again at the next interval.
  • When it receives a 502, you'd like/expect it to retry the toggle request after the specified interval.

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?

Still, it might be good to have some better handling of server errors.

That's a fair point! What would you classify as "better handling" in this case? What would you expect? ☺️

@skairunner
Copy link
Author

skairunner commented Jun 16, 2022

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 poll: failed to retrieve features; with PR #36 it says poll: failed to retrieve features - Error("expected value", line: 2, column: 1) which is not incredibly helpful either. In the project I'm working on, I added a small hack to print the actual json value that failed to parse which is how I discovered the issue. So I guess what is really needed is improved error reporting.

Please feel free to close this issue!

@thomasheartman
Copy link
Contributor

Got it! In that case I'll close this for now ☺️ I think getting some more information would be good though; maybe it's something that can be worked into #36?

Repository owner moved this from Todo to Done in Issues and PRs Jun 17, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
Archived in project
Development

No branches or pull requests

4 participants