1:已经有Docker hub了,为什么还要搭建私有仓库?
Docker hub为我们提供了很多官方镜像和个人上传的镜像,我们可以下载机构或个人提供的镜像(如ubuntu,busybox...),也可以上传我们自己的本地镜像,然后我们需要的时候也可以随时下载。看着很是方便,但是也有不方便的地方:
(1)那就是我们在从dockerhub上下载和上传镜像速度可能受影响,有时可能docker主页都打不开。
(2)我们在生产上所使用的docker镜像可能存放着我们的code,tools,不想被外部人员获取,只允许内网的开发人员下载。如果上传到dockerhub上所有人都可以看到。这和github上的公共库是一样的。
(3)在内部网络搭建docker私有仓库可以使内网人员下载和上传都非常快速,不受外网带宽等因素的影响,同时不在内网的人员无法下载我们的镜像,上述两个缺点都很好的解决了
2:开始搭建简单的docker私有仓库
搭建环境ubuntu14.04
(1)创建docker用户,并为docker添加sudo权限 (不想创建多与用户的请忽略步骤(1))
我首先是创建了一个docker 用户,可以不创建,我创建的目的是让这个docker 用户专门来处理私有仓库
useradd -d /home/docker -g docker docker #创建docker用户的同时直接加入docker组(dokcer组在docker安装完后就已经存在,若用adduser docker会提示组已存在)
chmod 640 /etc/sudoers #加写权限
vim sudoders
-------------------------------------------------
# User privilege specification
root ALL=(ALL:ALL) ALL
docker ALL=(ALL:ALL) ALL #添加此行,保存退出
然后再将/etc/sudoers权限改成440
(2) 创建一个目录,来存放docker仓库的镜像
这里我用docker用户来搭建docker仓库,在home目录下又创建一个docker_registry目录在存放未来的docker仓库的镜像,将用户/组都改成了docker
(3)开始创建我们的仓库,首先下载registry镜像
docker pull registry
docker run -d -p 5000:5000 -v /home/docker_registry: /var/lib/registry registry
至此我们就创建了一个私有仓库,地址在本机的5000端口上,我的是192.168.2.114,即:192.168.2.114:5000
测试调试
接下来我们就要操作把一个本地镜像push到私有仓库中
在内网的任意一台装有docker的机器下pull一个比较小的镜像来测试(此处使用的是busybox)
docker pull busybox
接下来修改一下该镜像的tag。
docker tag busybox 192.168.2.114:5000/busybox
接下来把打了tag的镜像上传到私有仓库。
docker push 192.168.2.114:5000/busybox
可以看到push失败,具体错误如下:
因为Docker从1.3.X之后,与docker registry交互默认使用的是https,然而此处搭建的私有仓库只提供http服务,所以当与私有仓库交互时就会报上面的错误。为了解决这个问题需要在启动docker server时增加启动参数为默认使用http访问。修改docker启动配置文件(此处是修改132机器的配置)Ubuntu下配置文件地址为:/etc/default/docker,在其中增加–insecure-registry 192.168.2.114
:5000如下所示:
修改完之后,重启Docker服务
sudo restart docker
重启完之后我们再次运行推送命令,把本地镜像推送到私有服务器上。
docker push 192.168.2.114:5000/busybox
可以看到镜像已经push到私有仓库中去了。
接下来我们删除本地镜像,然后从私有仓库中pull下来该镜像。
docker pull 192.168.2.114:5000/busybox
查看镜像
# curl -XGET http://registry:5000/v2/_catalog
# curl -XGET http://registry:5000/v2/image_name/tags/list
删除镜像
虽然看了官方API,但是还是不能成功删除,Docker Registry HTTP API V2
根据网上资料显示,当前版本尚不支持该功能,再等等看新版本吧,有第三方工具可以删除,感兴趣的可以自行查一下。