前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker | 教你搭建属于自己的镜像仓库

Docker | 教你搭建属于自己的镜像仓库

作者头像
咸鱼学Python
发布2019-10-09 14:40:17
3.3K0
发布2019-10-09 14:40:17
举报
文章被收录于专栏:咸鱼学Python咸鱼学Python

学了这么久的Docker,相信大家也根据自己的需求构建了不少的镜像,但是打包,上传镜像太过麻烦,如果有一个属于自己的仓库来存放岂不美哉?

想用哪个就下哪个,学完这篇你距离拥有自己的Docker兵器库就不远了。

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

docker pull 用法可以参考docker系列文章的第一篇:

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

主要步骤如下:

  • 第一步:在需要搭建仓库的服务器上安装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端口访问)
向私有仓库上传、下载镜像
  • 第一步:利用docker tag重命名需要上传的镜像 docker tag IMAGE 服务器IP:端口/IMAGE_NAME
  • 第二步:利用docker push上传刚刚重命名的镜像 docker push 服务器IP:端口/IMAGE_NAME
  • 注意: 必须重命名为服务器IP:端口/IMAGE_NAME 如果push出现了类似https的错误那么需要往配置文件/etc/docker/daemon.json里添加:”insecure-registries”:[“服务器IP:端口”] 然后重启docker。
搭建带认证的私有仓库

在服务器上:

  • 第一步:删除先前创建的无认证的仓库容器 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
带认证的私有仓库,如何上传、下载镜像

在本地机器上:

  • 第一步:首先登录到服务器 docker login -u username -p password 服务器IP:8000
  • 第二步:然后执行pull或者push命令,参考无认证仓库的上传/下载
  • 第三步:操作完毕后,可以退出登录 docker logout 服务器IP:8000

这是如果想查看仓库中已有的镜像,那么需要进行http验证才可以。可以直接借助浏览器访问服务器IP:8000/v2/_catalog就可以访问了

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-02-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 咸鱼学Python 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是Docker仓库
  • 如何搭建无认证私有仓库
  • 向私有仓库上传、下载镜像
  • 搭建带认证的私有仓库
  • 带认证的私有仓库,如何上传、下载镜像
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档