docker私人仓库 docker创建registry仓库
环境声明
centos7
docker镜像仓库:192.168.157.128
docker客户端:192.168.157.129
1、128搭建本地registry
[root@localhost ~]# docker pull registry [root@localhost ~]# docker images 2、基于私有仓库镜像运行容器
[root@localhost ~]# docker run -d -p 5000:5000 -v /opt/registry:/tmp/registry docker.io/registry [root@localhost ~]# docker ps -a 3、访问私有仓库
[root@localhost ~]# curl 127.0.0.1:5000/v1/search {“num_results”: 0, “query”: “”, “results”: []} #私有仓库为空,没有提交新镜像到仓库中
网上都用这个curl 127.0.0.1:5000/v1/search,但是报404 page not found,后查证是v1版本的api查看方式,我们现在的版本是v2,所以用如下方法查看:
[root@localhost ~]# curl 127.0.0.1:5000/v2/_catalog {“repositories”:[]} #私有仓库为空,没有提交新镜像到仓库中 4、从Docker Hub上下载一个ssh镜像
[root@localhost ~]# docker search -s 10 ssh [root@localhost ~]# docker pull fedora/ssh [root@localhost ~]# docker images 5、创建镜像链接或为基础镜像打个标签
[root@localhost ~]# docker tag docker.io/fedora/ssh 127.0.0.1:5000/ssh #库名不能有大写字母 [root@localhost ~]# docker images 6、修改Docker配置文件制定私有仓库url
[root@localhost ~]# vim /etc/docker/daemon.json 添加此行 不添加报错,https证书问题 {“insecure-registries”:[“192.168.157.128:5000”]} [root@localhost ~]# service docker restart 7、提交镜像到本地私有仓库中
[root@localhost ~]# docker push 127.0.0.1:5000/ssh 8、查看私有仓库是否存在对应的镜像
[root@localhost ~]# curl 127.0.0.1:5000/v2/_catalog 从私有仓库中下载已有的镜像 1、登陆另外一台Docker客户端
[root@localhost ~]# ssh root@192.168.0.110 2、修改Docker配置文件
[root@localhost ~]# vim /etc/docker/daemon.json 不添加报错,https证书问题 {“insecure-registries”:[“192.168.157.128:5000”]} [root@localhost ~]# service docker restart 3、查看私有仓库是否存在对应的镜像
[root@localhost ~]# curl 192.168.157.128:5000/v2/_catalog [root@localhost ~]# curl 192.168.157.128:5000/v2/ssh/tags/list 4、从私有仓库中下载已有的镜像
[root@localhost ~]# docker pull 127.0.0.1:5000/ssh [root@localhost ~]# docker images 验证是否下载成功