有时候使用 Docker Hub 这样的公共仓库可能不方便,用户能够建立一个本地仓库供私人使用。本节介绍如何使用本地仓库。git
你能够经过获取官方 registry 镜像来运行docker
$ docker run -d -p 5000:5000 --restart=always --name registry registry
复制代码
这将使用官方的 registry 镜像来启动私有仓库。默认状况下,仓库会被建立在容器的 /var/lib/registry 目录下。你能够经过 -v 参数来将镜像文件存放在本地的指定路径。例以下面的例子将上传的镜像放到本地的 /opt/data/registry 目录。json
$ docker run -d \
-p 5000:5000 \
-v /opt/data/registry:/var/lib/registry \
registry
复制代码
建立好私有仓库以后,就可使用 docker tag 来标记一个镜像,而后推送它到仓库。例如私有仓库地址为 127.0.0.1:5000。先在本机查看已有的镜像。ubuntu
$ docker image ls
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
ubuntu latest ba5877dc9bec 6 weeks ago 192.7 MB
复制代码
使用 docker tag 将 ubuntu:latest 这个镜像标记为 127.0.0.1:5000/ubuntu:latest。centos
格式为 docker tag IMAGE[:TAG] [REGISTRY_HOST[:REGISTRY_PORT]/]REPOSITORY[:TAG]。bash
$ docker tag ubuntu:latest 127.0.0.1:5000/ubuntu:latest
$ docker image ls
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
ubuntu latest ba5877dc9bec 6 weeks ago 192.7 MB
127.0.0.1:5000/ubuntu:latest latest ba5877dc9bec 6 weeks ago 192.7 MB
复制代码
使用 docker push 上传标记的镜像。curl
$ docker push 127.0.0.1:5000/ubuntu:latest
The push refers to repository [127.0.0.1:5000/ubuntu]
373a30c24545: Pushed
a9148f5200b0: Pushed
cdd3de0940ab: Pushed
fc56279bbb33: Pushed
b38367233d37: Pushed
2aebd096e0e2: Pushed
latest: digest: sha256:fe4277621f10b5026266932ddf760f5a756d2facd505a94d2da12f4f52f71f5a size: 1568
复制代码
$ curl 127.0.0.1:5000/v2/_catalog
{"repositories":["ubuntu"]}
复制代码
若是你不想使用 127.0.0.1:5000 做为仓库地址,好比想让本网段的其余主机也能把镜像推送到私有仓库。你就得把例如 192.168.199.100:5000 这样的内网地址做为私有仓库地址,这时你会发现没法成功推送镜像。ui
这是由于 Docker 默认不容许非 HTTPS 方式推送镜像。咱们能够经过 Docker 的配置选项来取消这个限制,或者查看下一节配置可以经过 HTTPS 访问的私有仓库。url
对于使用 systemd 的系统,请在 /etc/docker/daemon.json 中写入以下内容(若是文件不存在请新建该文件)spa
{
"registry-mirror": [
"https://registry.docker-cn.com"
],
"insecure-registries": [
"192.168.199.100:5000"
]
}
复制代码
注意:该文件必须符合 json 规范,不然 Docker 将不能启动。
本文引自:yeasy.gitbooks.io/docker_prac…