部署私有仓库应用
私有仓库镜像:
registry --官方出品, 没有图形界面。Docker hub官方已提供容器镜像registry,用于搭建私有仓库
拉取镜像:
[root@docker-server ~]# docker pull daocloud.io/library/registry:latest
运行容器:
docker run -itd -p 5000:5000 -v /home/dockerdata/registry:/var/lib/registry --name pri_registry --restart=always daocloud.io/library/registry:latest
参数解释:
/home/dockerdata/registry表示为宿主机的目录,如果不存在自动创建
-v映射目录: 宿主机的目录:容器目录
把宿主机的目录挂载到容器中,将数据目录挂载出来就是为了防止docker私有仓库这个容器被删除的时候,仓库里面的镜像也被删除。
-p 端口映射:本地端口:容器端口
注:如果创建容器不成功,报错防火墙,解决方案如下
#systemctl stop firewalld
#yum install iptables*
#systemctl start iptables
#iptables -F
#systemctl restart docker
[root@docker-server ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
0823df72b160 daocloud.io/library/registry "/entrypoint.sh /etc…" About a minute ago Up About a minute 0.0.0.0:5000->5000/tcp pri_registry
连接容器查看端口状态:我这里做了个快捷方式
vim /usr/bin/ds
ds 0823df7 #快捷方式
[root@docker-server ~]# docker exec -it 0823df7 /bin/sh
/ # netstat -lntp #查看5000端口是否开启
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 :::5000 :::* LISTEN 1/registry
/ #
在本机查看能否访问该私有仓库, 看看状态码是不是200
[root@docker-server ~]# curl -I http://127.0.0.1:5000
HTTP/1.1 200 OK
为了测试,下载1个比较小的镜像,buysbox
[root@docker-server ~]# docker pull daocloud.io/library/busybox
上传前必须给镜像打tag 注明ip和端口:
[root@docker-server ~]# docker tag daocloud.io/library/busybox 196.196.196.44:5000/busybox
下面这个Mysql是我测试的第二个镜像,从daocloud拉取的:
[root@docker-server ~]# docker pull daocloud.io/library/mysql
[root@docker-server ~]# docker tag daocloud.io/library/mysql 196.196.196.44:5000/daocloud.io/library/mysql
[root@docker-server ~]# docker images
注:tag后面可以使用镜像名称也可以使用id,我这里使用的镜像名称,如果使用官方的镜像,不需要加前缀,但是daocloud.io的得加前缀.
上传镜像到私有仓库:
[root@docker-server ~]# docker push 196.196.196.44:5000/busybox
[root@docker-server ~]# docker push 196.196.196.44:5000/daocloud.io/library/mysql
会出现报错,需要修改请求方式为http:
默认为https,不改会报以下错误:
Get https://master.up.com:5000/v1/_ping: http: server gave HTTP response to HTTPS client
[root@docker-server ~]# vim /etc/docker/daemon.json #不存在则创建
{ "insecure-registries":["196.196.196.44:5000"] }
重启docker:
[root@docker-server ~]# systemctl restart docker
从新上传即可
宿主机查看存放镜像目录:
[root@docker-server ~]# ls /home/dockerdata/registry/docker/registry/v2/repositories/
查看私有仓库里的所有镜像:
语法: # curl http://ip:port/v2/repo名字/tags/list
[root@docker-server ~]# curl http://196.196.196.44:5000/v2/busybox/tags/list
{"name":"busybox","tags":["latest"]}
这条命令会查看仓库下面镜像的版本
[root@docker-server ~]# curl http://196.196.196.44:5000/v2/daocloud.io/library/mysql/tags/list
{"name":"daocloud.io/library/mysql","tags":["latest"]}
这条命令会查看仓库下面所有的镜像:
[root@docker-server ~]# curl http://196.196.196.44:5000/v2/_catalog
拉取镜像测试:
1.先将刚才打了tags的镜像删掉
[root@docker-server ~]# docker rmi 192.168.246.141:5000/busybox
2.拉取镜像:
[root@docker-server ~]# docker pull 192.168.246.141:5000/busybox
[root@docker-server ~]# docker images
虚拟机进行测试
先去查看私有仓库都有什么镜像
[root@docker-server2 ~]# curl http://196.196.196.44:5000/v2/_catalog
{"repositories":["busybox"]}
这个是查看私有仓库镜像,都有什么版本
[root@docker-server2 ~]# curl http://196.196.196.44:5000/v2/busybox/tags/list
{"name":"busybox","tags":["latest"]}
进项拉取 会报错
需要配置仓库的ip加端口
vim /etc/docker/daemon.json
{ "insecure-registries":["196.196.196.44:5000"] }
重启docker:
[root@docker-server2 ~]# systemctl restart docker
从新进行拉取,拉取成功
docker pull 196.196.196.44:5000/busybox
尝试上传镜像到私有仓库,首先要打tag 重点
[root@docker-server2 ~]# docker tag centos:7.8 196.196.196.44:5000/centos:v3
[root@docker-server2 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos7 v1 3e98bae69bb2 10 hours ago 378MB
196.196.196.44:5000/centos v3 6ef539cfecf0 10 hours ago 402MB
centos 7.8 6ef539cfecf0 10 hours ago 402MB
196.196.196.44:5000/busybox latest a9d583973f65 8 months ago 1.23MB
进项上传
[root@docker-server2 ~]# docker push 196.196.196.44:5000/centos:v3
The push refers to repository [196.196.196.44:5000/centos]
d44da13c95bd: Pushed
613be09ab3c0: Pushed
v3: digest: sha256:21b8ef7069150f7b643212831a370fa78381628bac8b1af0c22d07b5315c710c size: 741
本机查看,私有仓库有没有更新
curl http://196.196.196.44:5000/v2/_catalog
{"repositories":["busybox","centos"]}
私有仓库主机查看,有没有更新