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

feat: do not fail if server returns 200 OK #1120

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

scabala
Copy link
Contributor

@scabala scabala commented Oct 23, 2024

Another rather easy fix.

Closes #958

FYI @dmacvicar @volker-raschek @hansingt

@scabala scabala mentioned this pull request Oct 23, 2024
1 task
@hansingt
Copy link

hansingt commented Oct 24, 2024

Thanks for the fix @scabala!

Some thoughts I have about this change and the code here in general:

If we accept HTTP 200 responses here, the response might contain the whole image. This depends on whether the http go module supports streaming or not. But I'd guess it does.

If it does, only the first chunks will be received until the network buffer is filled. Thus, this is not that much of waste of network traffic, but should be considered. Maybe, it should be considered / checked, whether the IsQCOW2 check could be merged with the Import method, to download things only once? But this might be a separate issue.

Anyway, right now, the io.ReadAll() in Line 147 causes the whole image to be downloaded. This does not only block until the download is complete, it does also waste (possibly several gigabytes) memory, or might even fail, if the computer runs out of memory. This depends on the size of the image to be downloaded.

We already know, that we only need the first 8 bytes of the file, thus, it would be better to only read that much. Maybe
io.ReadFull would be correct here?

Last, but not least, actually, all HTTP Codes in the 200-299 range are to be considered as successful responses, but that doesn't really matter here, because the other status codes defined in this range arn't important in this case (see https://developer.mozilla.org/en-US/docs/Web/HTTP/Status#successful_responses).

Besides this, this change looks good for me! 👍

@scabala
Copy link
Contributor Author

scabala commented Oct 24, 2024

Thanks for review.

First of all, I was aiming for minimal change as I do not (yet) know codebase very well. In general, it should work well but could be improved.

I'll try to use io.ReadFull, should be a better fit.

I also thought about all 2xx status codes but decided to keep it simple and minimal change. However, if others deem it worth it, I'll change it to accept other 2xx status codes as well.

@dmacvicar
Copy link
Owner

I understand the ReadFull is harmless if the server answered with StatusPartialContent.

I don't get why we should support servers that do not accept ranges? What problem are we trying to solve?

@hansingt
Copy link

hansingt commented Oct 27, 2024

I understand the ReadFull is harmless if the server answered with StatusPartialContent.

I don't get why we should support servers that do not accept ranges? What problem are we trying to solve?

Hi @dmacvicar,

Please see #958 (comment):

There are HTTP-Servers, which do not support Range-Requests, like the talos download servers. And according to the RFC 9110, they don't have to, as it is an optional feature.

In this case, the server is responding with a normal HTTP 200 response which contains the whole image.

Thus, to support these servers, it would be better to explicitly only read the first bytes required from the request, to avoid loading the whole image into memory.

@jonkerj
Copy link

jonkerj commented Jan 13, 2025

@dmacvicar did you get a chance to look into this? This bug/feature is blocking IAC-ing Talos deployments using Terraform in a clean way, and it seems Talos servers are behaving according to RFC 9110.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

can't retrieve partial header
4 participants