您的位置:首页 > 运维架构 > Docker

docker registry私有仓库搭建

2019-05-04 00:00 841 查看

前提:已安装好docker,不懂安装的可以查看CentOS 7下使用docker-compose部署Django与MySQL实战 https://www.linuxidc.com/Linux/2019-05/158468.htm

系统:CentOS 7

一、pull registry镜像到本地

docker pull registry

二、运行registry镜像

docker run -d -p 5000:5000 -v /home/$user/registry:/var/lib/registry registry

三、查看registry是否成功启动且可用

docker ps -a #查看registry容器状态

如果本机有图形界面,在浏览器中访问 http://127.0.0.1:5000/v1/,看到如下内容则表示registry可用

如果没有图形界面,则执行命令: curl -XGET http://127.0.0.1:5000/v2,可以看到返回一个{}

四、修改/etc/docker/daemon.js文件配置,增加如下内容(客户端、服务器端都需要做该配置,在本机只需要配置一次就可以):

{
    "insecure-registries": ["127.0.0.1:5000"]
}

如果当前已有内容,则在原文件的{}里面的末尾追加内容即可,正常情况来说,自己搭建registry仓库是方便多人使用,这个时候就需要增加多个insecure-registries内容,示例如下:

{
    "insecure-registries": ["127.0.0.1:5000","192.168.1.5:5000","xxx.cn:5000"]
}

如果不执行该操作,在push镜像的时候会报错:http: server gave HTTP response to HTTPS client

原因是Docker从1.3.X之后,与docker registry交互默认使用的是https,然而此处搭建的私有仓库只提供http服务,所以当与私有仓库交互时就会报上面的错误。

当然另外一种解决方案就是给服务器开启https协议

五、通过docker tag重命名镜像

docker pull busybox #先下载最新的镜像
docker tag busybox:latest 127.0.0.1:5000/busybox:v1 #tag

六、push tag后的镜像到registry

docker push 127.0.0.1:5000/busybox:v1

七、验证镜像已成功push

在浏览器访问:http://127.0.0.1:5000/v2/_catalog,成功时会显示busybox

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息