Docker仓库实际上提供两方面的功能,一个是镜像管理,一个是认证。
前者主要由docker-registry项目来实现,通过http服务来上传下载;后者可以通过docker-index项目或者利用现成认证方案实现http请求管理。

使用官方仓库:简单,但是速度慢

登陆dockerhub官网创建用户并登陆既可使用官方提供的dockerhub空间,增加自己的userID作为上传的根目录实现images的版本控制
https://hub.docker.com/
http://note.youdao.com/noteshare?id=54dad70770ed572d8ba05e35f05104d2&sub=A354A2FC89EB4F1C81302EF5A186FB8F
创建后在dockers服务器上使用docker login进行登陆,登陆后即可进行仓库的上传下载动作

本地自建仓库:复杂,速度快,安全

1、使用官方镜像创建
配置文件

官方镜像开出的registry也是一个容器,如果不指定镜像存储位置为一个宿主机的磁盘位置的话可能会导致镜像丢失,所以需要用-v参数挂载本地的存储上去
docker run -d -p 5000:5000 -v /data/docker_images:/tmp registry:0.9.1
##标红部分可以自己指定宿主机的一个存储位置
这种方式创建较为简单快捷

1)在安装有docker服务的服务器上运行:

docker run -d -p 5000:5000 -v /data/docker_images:/tmp registry:0.9.1

运行结果如下:

2)docker ps (查看正在运行中的docker容器)

3)由于第一步创建时没有加--name参数,所以容器创建会产生一个随机name,为了管理方便对容器进行重命名
docker rename keen_banach registry

4)查看容器对于的日志
docker logs registry(容器名或ID)

5)通过get访问查看容器运行是否正常

curl localhost:5000

相当于浏览器直接访问返回的结果(这部分返回值是由registry容器镜像制作时dockerfile中引用决定的)

6)查看宿主机上的挂载位置:(新增了一个*.db文件)

ls /data/docker_images

内容如下:(是一条sqlite的SQL语句)

7)在本地测试上传一个镜像:
#docker images (查看本地的镜像文件)

#docker tag rancher/agent:v1.2.11 10.234.2.182:5000/rancher-agent:v1(对其中一个镜像重命名)

一顿操作,完全失败,无法上传,报错404
最终确诊是由于docker 1.3版本以后默认已经支持到了registry v2 版本,而v2版本会涉及到https和鉴权,所以按照原来的路径push的话始终无法完成上传的动作;

v2版本的dir路径:/var/lib/registry

v1版本的dir路径:/tmp/registry

解决方法
或者docker降级,或者registry升级到v2版本,并且重新配置,v2版本相交于v1更加合理,但是配置也更加繁琐
8)最终解决方式使用registry v2版本代替

docker run -d -p 5000:5000 --name registry registry:latest

9)上传镜像

docker push 132.232.204.252:5000/rancher-agent

客户端和服务端上传均会报错,报错信息:
The push refers to repository [132.232.204.252:5000/rancher-agent]
Get https://132.232.204.252:5000/v2/: http: server gave HTTP response to HTTPS client
大致意思就是客户端用https的请求服务端返回了http的返回
因为Docker从1.3.X之后,与docker registry交互默认使用的是https,然而此处搭建的私有仓库只提供http服务,所以当与私有仓库交互时就会报https错误。为了解决这个问题需要在启动docker server时增加启动参数为默认使用http访问。
解决方法有两种思路:
一、本地配置信任
修改docker.service文件中的start启动项
路径一般为:/usr/lib/systemd/system/
vim /usr/lib/systemd/system/docker.service

ExexStart=/usr/bin/dockerd -H unix:// 在改行后增加需要信任的服务端地址
--insecure-registry 127.0.0.1:5000 --insecure-registry 132.232.204.252:5000

修改后需要重新加载deamon
重启docker服务
#systemctl daemon-reload
#systemctl restart docker.service
查看docker info 修改前后对比增加了信任的注册registries

再进行上传即可成功

查看仓库web中也新增了镜像

二、在服务端配置nginx代理,增加证书

============================================================================
docker-registry版本发展
1、2013年3月13日
docker在github上有了第一个release[3]
2、2013年7月3日
docker在github上发布了docker registry v1[4]
3、2015年1月30日
docker registry v2(项目名叫docker distribution)有了第一个release,同时停止更新docker registry v1[5]
4、2015年4月16日
docker发布docker1.6,同时正式推广docker registry v2
在使用docker registry v2的时候需要注意,只有docker1.6以上版本才支持registry v2,但是docker是向前兼容的,我们从源代码里可以看出,docker engine在下载镜像的时候,会先判断远端仓库是v1还是v2版,从而使用不同的下载策略,这个策略可太重要了

坑点:
1、docker的发展有两部分,一是在2017年3月之前docker一直使用的版本命名方式是docker1.xx,这种方式的最后一个版本是docker1.13.1版本,在2017年3月,改用年分命名方式,第一版docker17.03,docker版本和redistry的结合部分在docker1.3版本发生一些变化,因为registry v2版本的出现
2、registry 建议直接使用v2版本,0.9.1是最后一个v1版本,虽然docker有向前兼容性,但是registry的v1和v2项目是完全不同的两个项目,并且不具有兼容性