docker registry私有仓库搭建

 

前提:已安装好docker,不懂安装的能够查看个人另外一篇博客使用docker-compose编排django、mysql实战html

系统:centos7mysql

 

1、pull registry镜像到本地sql

docker pull registry

 

2、运行registry镜像docker

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

 

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

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

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

若是没有图形界面,则执行命令: curl -XGET http://127.0.0.1:5000/v2,能够看到返回一个{}浏览器

 

4、修改/etc/docker/daemon.js文件配置,增长以下内容(客户端、服务器端都须要作该配置,在本机只须要配置一次就能够):服务器

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

若是当前已有内容,则在原文件的{}里面的末尾追加内容便可,正常状况来讲,本身搭建registry仓库是方便多人使用,这个时候就须要增长多个insecure-registries内容,示例以下:curl

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

若是不执行该操做,在push镜像的时候会报错:http: server gave HTTP response to HTTPS clientui

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

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

5、经过docker tag重命名镜像

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

 

6、push tag后的镜像到registry

docker push 127.0.0.1:5000/busybox:v1

7、验证镜像已成功push

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

 

更多实践能够参考http://www.javashuo.com/article/p-zuvnktoa-bk.html

相关文章
相关标签/搜索