Docker之仓库

Docker之仓库

一 Docker 仓库简介

1 什么是Docker仓库

• Docker仓库就是存放docker镜像并有docker pull方法下载的云环境

• Docker仓库分为公有仓库和私有仓库。

公有仓库指Docker Hub(官方)等开放给用户使用、允许用户管理镜像。
  私有仓库指由用户自行搭建的存放镜像的云环境。

二 Docker 私有仓库搭建

1 搭建无认证私有仓库

# 第一步: 在需要搭建仓库的服务器上安装docker。
# 第二步: 在服务器上,从docker hub下载registry仓库
	docker pull registry
# 第三步: 在服务器上,启动仓库
	docker run -d -ti --restart always\
			--name my-registry\
			-p 8000:5000\
			-v /my-registry/registry:/var/lib/registry\
 	registry
	# 注意:registry内部对外开放端口是5000。默认情况下,会镜像存放于容器内的/var/lib/registry(官网Dockerfile中查看)目录下,这样如果容器被删除,则存放于容器中的镜像也会丢失。

# 本地利用curl 服务器IP:8000/v2/_catalog  查看当前仓库中的存放的镜像列表。(注意打开8000端口访问)

2 私有仓库–上传、下载镜像

# 第一步: 利用docker tag重命名需要上传的镜像
	docker tag IMAGE 服务器IP:端口/IMAGE_NAME
# 第二步: 利用docker push上传刚刚重命名的镜像
	docker push 服务器IP:端口/centos

# 注意:
	必须重命名为服务器IP:端口/IMAGE_NAME
	如果push出现了类似https的错误那么需要往配置文件/etc/docker/daemon.json里添加:”insecure-registries”:[“服务器IP:端口”]  
	然后重启docker。

3 搭建带认证的私有仓库(一)

在服务器上:
	# 第一步:删除先前创建的无认证的仓库容器
		docker rm -f my-registry
	# 第二步:创建存放认证用户名和密码的文件:
		mkdir /my-registry/auth -p
	# 第三步:创建密码验证文件。注意将将USERNAME和PASSWORD替换为设置的用户名和密码
		docker run --entrypoint htpasswd registry -Bbn USERNAME PASSWORD > /my-registry/auth/htpasswd
	# 第四步:重新启动仓库镜像
    docker run -d -p 8000:5000 --restart=always --name docker-registry \
    -v /my-registry/registry:/var/lib/registry \
    -v /my-registry/auth:/auth \
    -e "REGISTRY_AUTH=htpasswd" \
    -e "REGISTRY_AUTH_HTPASSWD_REALM=Registry Realm" \
    -e "REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd" \
    registry

4 带认证的私有仓库 -上传、下载镜像

在本地机器上:
	# 第一步:首先登录到服务器
		docker login -u username -p password ip:8000
	# 第二步:然后执行pull或者push命令
  # 第三步:操作完毕后,可以退出登录
		docker logout ip:8000
 
# 这是如果想查看仓库中已有的镜像,那么需要进行http验证才可以。可以直接借助浏览器访问ip:8000/v2/_catalog就可以访问了

# 注意这里:47.94.153.230指服务器IP

5 总结

1 拉取私有仓库镜像
	docker pull registry
2 启动容器
	docker run -di --name=registry -p 5000:5000 registry
3 打开浏览器 输入地址http://ip:port/v2/_catalog看到{"repositories":[]} 表示私有仓库搭建成功并且内容为空
4 配置
	修改daemon.json
	vi /etc/docker/daemon.json
    添加以下内容,保存退出。
    {"insecure-registries":["ip:port"]} 
    此步用于让 docker信任私有仓库地址
5 重启docker 服务
	systemctl restart docker
6 重启容器
	docker start registry
7 打标签
	docker tag 镜像id ip:port/镜像名
8 上传到私有仓库
	docker push ip:port/镜像名
    
9 从私有仓库拉取镜像
	docker pull ip:port/镜像名
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

go&Python

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值