Docker Registry是官方提供的工具,可以用于构建私有镜像仓库
1. 下载镜像Docker Registry
docker pull registy
2. 运行私有库Registry,相当于本地有个私有Docker hub
docker run -d -p 5000:5000 -v /zzyyuse/myregistry/:/tmp/registry --privileged=true registry
默认情况,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷映射,方便于宿主机联调
3. 创建一个新镜像(具有ifconfig的ubuntu)
docker run -it ubuntu /bin/bash
apt-gte upadte
apt-get install net-tools
在容器外执行(可使用ctrl+q+p退出)
docker commit -m="提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]
4. curl验证私服库上有什么镜像
ifconfig查看ip为192.168.32.128
curl -XGET http://192.168.32.128:5000/v2/_catalog
可见现在私有库镜像为空
5. 将新镜像修改符合私服规范的Tag
使用命令 docker tag 将myubuntu:1.2 这个镜像修改为192.168.32.128:5000/myubuntu:1.2
docker tag 镜像:Tag Host:Port/Repository:Tag
docker tag myubuntu:1.2 192.168.32.128:5000/myubuntu:1.2
6. 修改配置文件使之支持http
vim命令新增如下加粗内容:(别忘了逗号)
vim /etc/docker/daemon.json
{
"registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"],
"insecure-registries": ["192.168.111.162:5000"]
}
docker默认不允许http方式推送镜像,通过配置选项来取消这个限制。 修改完后如果不生效,建议重启docker
7. push推送到私服库
docker push 192.168.32.128:5000/myubuntu:1.2
8. 再次curl验证私服库上有什么镜像
curl -XGET http://192.168.32.128:5000/v2/_catalog
9. pull到本地并运行
为演示,先删除原有192.168.32.128:5000/myubuntu:1.2
docker pull 192.168.32.128:5000/myubuntu:1.2
拉起成功