Я понимаю, что уже есть принятый ответ, однако я хотел предложить это решение, которое, я думаю, более непосредственно отвечает на заданный вопрос: «Как загрузить образ Docker без использования Docker для выполнения поиска?»
У меня есть похожая проблема, когда политики моей компании требуют от меня предоставления файла (ов) (обычно посредством URL), которые я хочу использовать. Затем они будут выполнять различные проверки и проверки, а затем помещать файлы в нашу отключенную сеть разработки. Я не могу использовать Docker, чтобы получить файл, затем экспортировать его и передать его этой команде, поэтому другой предоставленный ответ не был для меня вариантом.
К счастью, я нашел этот ответ в StackOverflow, который рекомендует использовать полезный инструмент, предоставленный samalba на GitHub: https://github.com/samalba/docker-registry-debug
Конечно, этот инструмент должен был быть построен с использованием Docker, и отчасти я нуждаюсь в нем, потому что у меня нет открытого доступа к Docker :). Итак, поскольку у меня не было этой опции, я объясню шаги, которые я предпринял здесь (это все с коммита 05fffc4344fd6f866f84c403caae3ba81193dd45 из этого репо):
$ go get github.com/dustin/go-humanize
$ go build
$ ./docker-registry-debug --help
$ ./docker-registry-debug curlme docker ubuntu
Результатом этой команды является полная командная строка curl, которую можно использовать для загрузки файла:
# Reading user/passwd from env var "USER_CREDS"
# No password provided, disabling auth
# Getting token from https://index.docker.io
# Got registry endpoint from the server: https://registry-1.docker.io
# Got token: signature=e145911c2e458b3842e4e92c90bbf5bf2c17bd56,repository="library/docker",access=read
curl -i --location-trusted -I -X GET -H "Authorization: Token signature=e145911c2e458b3842e4e92c90bbf5bf2c17bd56,repository="library/docker",access=read" https://registry-1.docker.io/v1/images/ubuntu/layer
Надеюсь, это поможет кому-то еще!