Docker系列(四)Centos6.5 搭建私人镜像仓库 v2
2017-11-14 21:27
656 查看
1、下载、运行registry
下载registry镜像:$ docker pull hub.c.163.com/library/registry
这个下载的过程有点长,耐心等待一下。O(∩_∩)O哈哈~。
$ docker images
registry镜像下下来后。通过以下的命令启动,并将registry的容器存储images的文件夹映射到宿主server的/opt/docker/registry文件夹。
$ docker run -d -p 5000:5000 -v /opt/docker/registry:/var/lib/registry registry
执行push命令之后,/var/lib/registry registry文件夹下有一个v2文件夹,所有上传的镜像都会在此文件夹下。
启动以后在浏览器中输入http://主机IP:5000或者http://主机IP:5000/v2/_catalog。假设有显示就说明Docker私有仓库已经建好了。下一步将本地的images push到Docker私有仓库。
2、重新对已有镜像打tag
现将本地的image打一个tag,新image名称必须带有"主机IP:5000"。例如以下(我这里用127.0.0.1仅仅是举例)。docker tag 5562556b14f9 127.0.0.1:5000/registry :latest
执行docker images查看是否打成功
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE registry latest 5562556b14f9 8 days ago 422.9 MB 127.0.0.1:5000/registry latest 5562556b14f9 8 days ago 422.9 MB
3、push镜像
$ docker push 127.0.0.1:5000/registry
下次能够通过pull命令下载到其它server上,那可就快多了。
pull的时候记得带"主机IP:5000",不然还是去Docker hub上下载而不是私有仓库下载,例如以下命令。
$ docker pull 127.0.0.1:5000/registry
到此。私有仓库存取image就够了。
出现的问题:
问题一假设是save/load的image。会出现以下的错误。对于这种image。最好又一次build对应的Dockerfile。
$docker push 127.0.0.1:5000/nexus
The push refers to a repository [127.0.0.1:5000/nexus] (len: 1) Sending image list Pushing repository 127.0.0.1:5000/nexus (1 tags) 2014/10/27 14:50:37 HTTP code 400 while uploading metadata: {"error": "Missing key `id' in JSON"}
问题二:
docker1.3.0以后的版本号。增加了认证机制,docker pull & push会报例如以下错误:
$ docker push 127.0.0.1:5000/registry
2014/12/02 11:33:04 Error: Invalid registry endpoint https://127.0.0.1:5000/v2/: Get https://127.0.0.1:5000/v2/_ping: EOF. If this private registry supports only HTTP or HTTPS with an unknown CA certificate, please add `--insecure-registry 127.0.0.1:5000` to the daemon's arguments. In the case of HTTPS, if you have access to the registry's CA certificate, no need for the flag; simply place the CA certificate at /etc/docker/certs.d/127.0.0.1:5000/ca.crt
修改/etc/sysconfig/docker(Ubuntu下配置文件地址为:/etc/init/docker.conf),增加启动选项(已有参数的在后面追加),之后重启docker,不添加报错,https证书问题。
OPTIONS='--insecure-registry 192.168.0.179:5000' #CentOS 7系统 other_args='--insecure-registry 192.168.0.179:5000' #CentOS 6系统
相关文章推荐
- 在CentOS 7.2上搭建Docker私有镜像仓库
- centos7 Docker私有仓库搭建及删除镜像
- docker 搭建registry私有仓库 (Centos6.5)
- 【系列4】使用Dockerfile创建带tomcat的Centos Docker镜像
- 【系列8】使用Dockerfile创建带MongoDB的Centos Docker镜像
- 实战演练丨在Docker 企业版中打造专属的私人镜像仓库
- Docker应用--搭建Docker镜像的本地仓库
- centos下搭建docker私有仓库
- centos7 搭建docker内运行rabbitmq,然后再镜像ha方案的完全教程,暂时一个宿主机只能运行一个docker的rabbitmq,但是集群 ha都正常
- centos7系统下搭建docker本地镜像仓库
- CentOS 6.5 制作可以ssh登录的Docker镜像
- docker搭建私有仓库v2(Private Registry v2),自签发证书、公网访问、登录认证
- centos6.5 docker 搜索镜像出错
- CentOS 7 : Docker私有仓库搭建和使用
- centos 6.5 & docker1.7.1 & docker的阿里云代理镜像设置
- Centos 7 docker私有仓库的搭建
- CentOS 7 搭建docker仓库
- Docker镜像仓库Harbor之搭建及配置
- CentOS7搭建Docker私有仓库
- 基于 Harbor 搭建 Docker 私有镜像仓库