Docker-ls is a set of CLI tools for browsing and manipulating docker registries. In particular, docker-ls can handle authentication and display the sha256 content digests associated with tags.
Only V2 registries are supported. Both HTTP basic auth and docker style token authentication are supported for authentication.
Four ways there are to attain enlightenment.
Just download precompiled binaries for your platform from github.
If you have Docker installed, you may want to try this option. Clone the repository and do:
docker build -t docker-ls .
Example of running container:
$ docker run -it docker-ls docker-ls tags library/consul
requesting list . done
repository: library/consul
tags:
- latest
- v0.6.4
Or create aliases:
$ alias docker-ls='docker run -it docker-ls docker-ls'
$ alias docker-rm='docker run -it docker-ls docker-rm'
So you can do:
$ docker-ls tags library/consul
requesting list . done
repository: library/consul
tags:
- latest
- v0.6.4
and:
$ docker-rm | head -n 3
usage: docker-rm [options] <repository:reference>
Delete a tag in a given repository.
Provided that you sport an installation of golang, the latest version from master can be installed via
go get -d github.com/mayflower/docker-ls/...
go generate github.com/mayflower/docker-ls/...
go install github.com/mayflower/docker-ls/cli/...
Isn't a simple go get github.com/mayflower/docker-ls/cli/...
sufficient, you ask?
Indeed it is, but including the generate step detailed above will encode verbose version information
in the binaries.
Clone the repository and do make
. This will create a separate GOPATH
in build
and leave you with the binaries ready in build/bin
. Of course, you need
golang
installed for this.
Docker-ls contains two CLI tools: docker-ls
and docker-rm
.
docker-ls
is a browser for docker registries. Output is either encoded as YAML or
as JSON.
Three subcommands are available
docker-ls repositories
Obtains a list of repositories on the server. This is not supported by the official docker hub.docker-ls tags
Lists all tags in a a particular repository.docker-ls tag
Inspect a particular tag. This command displays a condensed version of the corresponding manifest by default, but the--raw-manifest
option can be used to dump the full manifest. The--parse-history
option can be used to display the JSON-encoded history within the manifest.
This list is not exhaustive; please consult the command line (-h
) help for all options.
--registry <url>
Connect to the registry at . The URL must include the protocol (http / https). By default,docker-ls
targets the official docker hub.--user <user>
Username for authentication.--password <password>
Password for authentication.--interactive-password
Read the password from an interactive prompt.--level <depth>
Therepositories
andtags
subcommands support this option for recursive output. Depths 0 (default) and 1 are supported. Please note the recursing means more API requests and may be slow.--json
Switch output format from YAML to JSON.--basic-auth
Use HTTP basic auth for authentication (instead of token authentication).--allow-insecure
Do not validate SSL certificates (useful for registries secured with a self-signed certificate).--manifest-version
Request either manifest version V2.1 (--manifest-version 1
or manifest version V2.2 (--manifest-version 2
, default) from the registry. Please note that deleting manifests from registry version >= 2.3 will work only with content digests from a V2.2 manifest.
List all repositories in a custom registry:
docker-ls repositories --registry https://my.registry.org --user hanni --password hanni123
List all repositories in a custom registry, including their tags:
docker-ls repositories --registry https://my.registry.org --user hanni --password hanni123 --level 1
List all tags in stuff/busybox using HTTP basic auth
docker-ls tags --registry https://my.registry.org --user hanni --password hanni123 --basic-auth stuff/busybox
Inspect tag stuff/busybox:latest, no authentication, JSON output.
docker-ls tag --registry https://my.registry.org --json stuff/busybox:latest
Inspect tag stuff/busybox:latest, no authentication, dump the raw manifest with parsed history as JSON.
docker-ls tag --registry https://my.registry.org --json --raw-manifest --parse-history stuff/busybox:latest
If no registry is specified, docker-ls
will target the official registry server
at https://index.docker.io
. Please note that:
- The official registry does not support repository listing via
docker-ls repositories
- Official repositories must be prefixed with
library/
, e.g.docker-ls tags library/debian
docker-rm
can delete particular tags. Example:
docker-rm --registry https://my.registry.org --user someuser --password somepass busybox:sha256:51fef[...]
(the digest has been truncated for brevity). Please consult the command line help for a full list of all arguments.
Some remarks:
- The tag must be specified as a sha256 content digest.
- While tags can be deleted, the current registry implementation will (to the best of my knowledge) not free the space associated with any resulting unused layers
- Deleting stuff is currently disabled by default in the official registry and needs to be enabled explicitly — check out this issue for details.
- Content digests obtained with
--manifest-version 1
will not work with registry version >= 2.3. - BE CAREFUL! The API does not implement undelete :)
Docker-ls is distributed under the terms of the MIT license.