docker私有仓库
安装运行 docker-registry
容器运行
通过获取官方 registry 镜像来运行
$ docker run -d -p 5000:5000 --restart=always --name registry registry
使用官方的 registry 镜像来启动私有仓库。默认情况下,仓库会被创建在容器的 /var/lib/re
gistry 目录下。可以通过 -v 参数来将镜像文件存放在本地的指定路径。
例:将上传的镜像放到本地的 /opt/data/registry 目录。
$ docker run -d \
-p 5000:5000 \
-v /opt/data/registry:/var/lib/registry \
registry
在私有仓库上传、搜索、下载镜像
创建私有仓库,使用 docker tag 标记一个镜像,推送它到仓库。
例:私有仓库地址为 127.0.0.1:5000
先在本机查看已有的镜像。
$ 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。
格式为 docker tag IMAGE[:TAG][REGISTRY_HOST[:REGISTRY_PORT]/]REPOSITORY[:TAG]
$ 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 上传标记的镜像。
$ 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 查看仓库中的镜像。
$ curl 127.0.0.1:5000/v2/_catalog
{"repositories":["ubuntu"]}
显示{“repositories”:[“ubuntu”]},表明镜像上传成功。
先删除已有镜像,再尝试从私有仓库中下载这个镜像。
$ docker image rm 127.0.0.1:5000/ubuntu:latest
$ docker pull 127.0.0.1:5000/ubuntu:latest
Pulling repository 127.0.0.1:5000/ubuntu:latest
ba5877dc9bec: Download complete
511136ea3c5a: Download complete
9bad880da3d2: Download complete
25f11f5fb0cb: Download complete
ebc34468f71d: Download complete
2318d26665ef: Download complete
查看下载镜像
$ docker image ls
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
127.0.0.1:5000/ubuntu:latest latest ba5877dc9bec 6 weeks ago 192.7 MB
注意事项
如果不想以 127.0.0.1:5000 作为仓库地址,想让本网段的其他主机也能把镜像推送到私有仓库。可以指定地址为 192.168.199.100:5000 这样的内网地址作为私有仓库地址,镜像推送未成功。因为 Docker 默认不允许非 HTTPS 方式推送镜像。可以通过 Docker 的配置选项来取消这个限制,或查配置能够通过 HTTPS 访问的私有仓库。
请在 /etc/docker/daemon.json 中写入如下内容(如果文件不存在请新建该文件)
{
"registry-mirror": [
"https://hub-mirror.c.163.com",
"https://mirror.baidubce.com"
],
"insecure-registries": [
"192.168.199.100:5000"
]
}
阿里云-容器镜像服务
创建一个Repository,创建了一个的仓库 test。
登录阿里云Docker Registry:
$ sudo docker login --username=***** registry.cn-beijing.aliyuncs.com
为镜像打标签:
$ sudo docker tag nginx:latest registry.cn-beijing.aliyuncs.com/repository02/test:11.0
推送到远程仓库:
$ sudo docker push registry.cn-beijing.aliyuncs.com/repository02/test:11.0
打开阿里云查看Docker Registry上Repository的信息:
客户端上拉取已上传的镜像:
$ docker image rmi registry.cn-beijing.aliyuncs.com/repository02/test:11.0
$ sudo docker pull registry.cn-beijing.aliyuncs.com/repository02/test:11.0