Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/joshdk/docker-retag
🐳 Retag an existing Docker image without the overhead of pulling and pushing
https://github.com/joshdk/docker-retag
docker docker-api docker-hub docker-image docker-registry go golang
Last synced: about 1 month ago
JSON representation
🐳 Retag an existing Docker image without the overhead of pulling and pushing
- Host: GitHub
- URL: https://github.com/joshdk/docker-retag
- Owner: joshdk
- License: mit
- Created: 2018-05-01T01:28:21.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-09-23T00:06:06.000Z (over 6 years ago)
- Last Synced: 2024-11-15T04:39:42.582Z (about 1 month ago)
- Topics: docker, docker-api, docker-hub, docker-image, docker-registry, go, golang
- Language: Go
- Homepage:
- Size: 22.5 KB
- Stars: 30
- Watchers: 5
- Forks: 9
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
[![CircleCI][circleci-badge]][circleci-link]
[![Go Report Card][go-report-card-badge]][go-report-card-link]
[![License][license-badge]][license-link]
[![Github downloads][github-downloads-badge]][github-release-link]
[![GitHub release][github-release-badge]][github-release-link]# Docker Retag
🐳 Retag an existing Docker image without the overhead of pulling and pushing
## Motivation
There are certain situation where it is desirable to give an existing Docker image an additional tag. This is usually acomplished by a `docker pull`, followed by a `docker tag` and a `docker push`.
That approach has the downside of downloading the contents of every layer from Docker Hub, which has bandwidth and performance implications, especially in a CI environment.
This tool uses the [Docker Hub API](https://docs.docker.com/registry/spec/api/) to pull and push only a tiny [manifest](https://docs.docker.com/registry/spec/manifest-v2-2/) of the layers, bypassing the download overhead. Using this approach, an image of any size can be retagged in approximately 2 seconds.
## Installing
### From source
You can use `go get` to install this tool by running:
```bash
$ go get -u github.com/joshdk/docker-retag
```### Precompiled binary
Alternatively, you can download a static Linux [release][github-release-link] binary by running:
```bash
$ wget -q https://github.com/joshdk/docker-retag/releases/download/0.0.2/docker-retag
$ sudo install docker-retag /usr/bin
```## Usage
### Setup
Since `docker-retag` communicates with the [Docker Hub](https://hub.docker.com/) API, you must first export your account credentials into the working environment. These are the same credentials that you would use during `docker login`.
```bash
$ export DOCKER_USER='joshdk'
$ export DOCKER_PASS='hunter2'
```The credentials must have both pull and push access for the Docker repository you are retagging.
### Examples
This tool can be used in a few simple ways. The simplest of which is using a
source image reference (similar to anything you could pass to `docker tag`) and
a target tag.##### Referencing a source image by tag name.
```bash
$ docker-retag joshdk/hello-world:1.0.0 1.0.1
Retagged joshdk/hello-world:1.0.0 as joshdk/hello-world:1.0.1
```##### Referencing a source image by `sha256` digest.
```bash
$ docker-retag joshdk/hello-world@sha256:933f...3e90 1.0.1
Retagged joshdk/hello-world@sha256:933f...3e90 as joshdk/hello-world:1.0.1
```##### Referencing an image only by name will default to using `latest`.
```bash
$ docker-retag joshdk/hello-world 1.0.1
Retagged joshdk/hello-world:latest as joshdk/hello-world:1.0.1
```Additionally, you can pass the image name, source reference, and target tag as seperate arguments.
```bash
$ docker-retag joshdk/hello-world 1.0.0 1.0.1
Retagged joshdk/hello-world:1.0.0 as joshdk/hello-world:1.0.1
``````bash
$ docker-retag joshdk/hello-world @sha256:933f...3e90 1.0.1
Retagged joshdk/hello-world@sha256:933f...3e90 as joshdk/hello-world:1.0.1
```In all cases, the image and source reference **must** already exist in Docker Hub.
## License
This library is distributed under the [MIT License][license-link], see [LICENSE.txt][license-file] for more information.
[circleci-badge]: https://circleci.com/gh/joshdk/docker-retag.svg?&style=shield
[circleci-link]: https://circleci.com/gh/joshdk/docker-retag/tree/master
[github-downloads-badge]: https://img.shields.io/github/downloads/joshdk/docker-retag/total.svg
[github-release-badge]: https://img.shields.io/github/release/joshdk/docker-retag.svg
[github-release-link]: https://github.com/joshdk/docker-retag/releases/latest
[go-report-card-badge]: https://goreportcard.com/badge/github.com/joshdk/docker-retag
[go-report-card-link]: https://goreportcard.com/report/github.com/joshdk/docker-retag
[license-badge]: https://img.shields.io/github/license/joshdk/docker-retag.svg
[license-file]: https://github.com/joshdk/docker-retag/blob/master/LICENSE.txt
[license-link]: https://opensource.org/licenses/MIT