-
Notifications
You must be signed in to change notification settings - Fork 210
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
Clarify PUT location with chunked upload #415
Comments
My understanding is the last |
That certainly seems to be the case in the registries I've tried. The other language that I believe could do with clarifying is this:
That "any" sounds like it's OK to use the location from any of the sequence of previous POST or PATCH requests, but that appears not to be the case: when experimenting with the docker registry, it requires the most recent location. There's actually a potential problem with that AFAICS: if a client is in the middle of a large upload and a network outage prevents a response reaching a client, the client might not be able to resume because they won't have the latest location value as expected by the server. I guess it's too late to change that now. |
I wouldn't say things are too late to change. See #366 that was adding this recently. Chunked uploads aren't well supported, the docker engine uses them with a single large chunk when pushing images. I'm not aware of any client tooling that defaults to chunked uploads. So this is one of the safer areas to clarify without risking breaking existing use cases. |
@sudo-bmitch One other possible change to make in that area would be to specify that the 416 response itself could contain information sufficient to make another correct PATCH request; for example, it could contain |
When uploading a blob in chunks, the spec says:
This implies to me that
<location>
can change with each successive POST, so there are potentiallyn + 1 locations in play for n chunks (one for the initial POST and one for each PATCH).
The final PUT request is documented as follows:
This doesn't make it clear which
<location>
should be used. Should it be the location returned by the most recent PATCH request, or the<location>
returned by the original POST?The text was updated successfully, but these errors were encountered: