Docker 仓库

若是还未了解过 Docker, 建议先阅读上一篇文章 初识 Dockerphp


仓库(Repository)就是存放镜像的地方。相似于 NodenpmPythonPyPihtml

注册服务器(Registry)的概念比较容易与仓库混淆。实际上注册服务器是用来管理仓库的服务器,一个服务器上能够存在多个仓库,而每一个仓库下能够有多个镜像。前端

例如对于仓库地址 hub.dockerpool.com/nginx 来讲,hub.dockerpool.com 是注册服务器的地址,nginx 是仓库名。linux

Docker Hub

目前 Docker 官方维护的一个公共仓库,大部分需求咱们均可以从 Docker Hub 中直接下载镜像来实现。nginx

注册

咱们能够在 hub.docker.com/ 注册一个 Docker 帐号。git

登陆

能够经过 docker login 命令在终端输入用户名及密码来完成 Docker Hub 的登陆。web

咱们也能够经过 docker logout 退出登陆。docker

镜像分类

经过上一篇文章能够知道,使用 docker search 搜索镜像时,搜索出来能够看到下面的镜像列表。npm

$ docker search nginx
NAME                              DESCRIPTION                                     STARS               OFFICIAL            AUTOMATED
nginx                             Official build of Nginx.                        12036               [OK]
jwilder/nginx-proxy               Automated Nginx reverse proxy for docker con…   1671                                    [OK]
richarvey/nginx-php-fpm           Container running Nginx + PHP-FPM capable of…   742                                     [OK]
linuxserver/nginx                 An Nginx container, brought to you by LinuxS…   78
bitnami/nginx                     Bitnami nginx Docker Image                      71                                      [OK]
tiangolo/nginx-rtmp               Docker image with Nginx using the nginx-rtmp…   56                                      [OK]
nginxdemos/hello                  NGINX webserver that serves a simple page co…   28                                      [OK]
jlesage/nginx-proxy-manager       Docker container for Nginx Proxy Manager        24                                      [OK]
jc21/nginx-proxy-manager          Docker container for managing Nginx proxy ho…   24
nginx/nginx-ingress               NGINX Ingress Controller for Kubernetes         22
privatebin/nginx-fpm-alpine       PrivateBin running on an Nginx, php-fpm & Al…   18                                      [OK]
schmunk42/nginx-redirect          A very simple container to redirect HTTP tra…   17                                      [OK]
blacklabelops/nginx               Dockerized Nginx Reverse Proxy Server.          12                                      [OK]
复制代码

根据是不是官方提供,能够将镜像分为两类。json

一类是相似 nginx 这样的镜像,被称为基础镜像或跟镜像。这些基础镜像由 Docker 公司建立、验证、支持、提供。这样的镜像每每使用单个单词做为名字。

还有一种类型,好比 feiben/nginx 镜像,它是由 Docker Hub 的注册用户建立并维护的,每每带有用户名称前缀。能够经过前缀 username/ 来指定使用某个用户提供的镜像,好比 feiben 用户。

推送镜像

用户登陆后能够经过 docker push 命令来把本身的镜像推送到 Docker Hub,例如将 nginx 镜像改为咱们本身的镜像,而后推送到 Docker Hub。

首先经过 docker pull nginxnginx 镜像下载到本地。

nginx 添加标签 docker tag nginx feiben/nginx:1.17.5

$ docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
feiben/nginx        1.17.5              f949e7d76d63        2 weeks ago         126MB
nginx               latest              f949e7d76d63        2 weeks ago         126MB
复制代码

将本身的镜像推送到 Docker Hub

$ docker push feiben/nginx:1.17.5
The push refers to repository [docker.io/feiben/nginx]
509a5ea4aeeb: Mounted from library/nginx
3bb51901dfa3: Mounted from library/nginx
2db44bce66cd: Mounted from library/nginx
1.17.5: digest: sha256:066edc156bcada86155fd80ae03667cf3811c499df73815a2b76e43755ebbc76 size: 948
复制代码

稍等片刻,咱们就能够搜索出推送的镜像了

$ docker search feiben
NAME                DESCRIPTION         STARS               OFFICIAL            AUTOMATED
feiben/nginx                            0
复制代码

自动构建

咱们能够经过 Docker Hub 指定跟踪一个目标网站(支持 GitHub 或 BitBucket)上的项目,项目一旦有新的提交或者建立了新标签,将会触发 Docker Hub 自动构建镜像并推送到 Docker Hub中。

设置自动构建的步骤以下:

  1. 登陆 Docker Hub
  2. 点击头像,选择 Account Setting 再选择 Linked Accounts 管理帐号
  3. 在 Docker Hub 中新建或选择已有的仓库,在 Builds 选项卡中选择 Configure Automated Builds
  4. 选取一个目标网站中的项目(须要含 Dockerfile)和分支
  5. 指定 Dockerfile 的位置,并保存

完成自动构建配置以后,指定的分支一旦提交代码就会触发自动构建,咱们能够在仓库页面的 Timeline 选项卡中查看每次构建的状态。

除了 Docker Hub 的自动构建外,咱们也可使用 Travis CI 等持续集成工具来实现自动构建。

私有仓库

公司的项目通常不予许咱们上传到 Docker Hub 这类的公共仓库中,全部学会建立一个私有仓库也是很是必要的。

容器运行

咱们能够经过获取官方的 registry 镜像来运行。

$ docker run -d -p 5000:5000 --restart=always --name registry registry
复制代码

这将使用官方提供的 registry 镜像来启动私有仓库。默认状况下,仓库会被建立在容器的 /var/lib/registry 目录下。咱们能够经过 -v 参数将镜像文件存放在本地的指定路径。

$ docker run -d \
> -p 5000:5000 \
> -v /opt/data/registry:/var/lib/registry \
> --restart=always \
> registry
复制代码

这时咱们能够经过浏览器访问 http://domain:5000/v2/_catalog 查看仓库是否启动成功。

  • 其中 domain 是你的域名或 ip 地址,下文中的 domain 同理。

在私有仓库搜索、上传、下载镜像

上传镜像

首先使用 docker tag 将本地的 nginx 镜像添加标签

$ docker tag nginx:latest domain/nginx:latest
复制代码

接下来就可使用 docker push 命令将镜像推送到咱们的私有仓库中

$ docker push domain/nginx:latest
The push refers to repository [domain/nginx]
Get https://domain/v2/: EOF
复制代码

出现上面的提示时,说明推送失败了。由于 Docker 默认使用 HTTPS 的方式推送镜像。咱们能够经过 Docker 的配置来取消这个限制。

对于 Linux 系统,咱们能够在 /etc/docker/deamon.jsondeamon.josn 文件不存在则新建该文件)添加下面的配置

{ "insecure-registries": ["domain:5000"] }
复制代码

对于桌面版,咱们能够在 Docker 的设置 Daemon 选项中的 Insecure registries 中加上 domain:5000

【注】若是仓库主机是远程服务器的话,须要将服务器与本地的 docker 配置进行修改

设置完成后再使用上面的命令进行推送。除了上面这种方式外,咱们也能够将私有仓库的地址配置成支持 HTTPS 访问的,本文就不做展开了。

$ docker push domain:5000/nginx:latest
The push refers to repository [domain:5000/nginx]
509a5ea4aeeb: Pushed
3bb51901dfa3: Pushed
2db44bce66cd: Pushed
latest: digest: sha256:066edc156bcada86155fd80ae03667cf3811c499df73815a2b76e43755ebbc76 size: 948
复制代码

当看到上面的信息时,说明已经推送成功了。咱们能够再次访问 http://domain:5000/v2/_catalog 进行验证

$ curl http://domain:5000/v2/_catalog
{"repositories":["nginx"]}
复制代码

看到这个说明上传成功了。

搜索镜像

搜索私有仓库的镜像并不能用 docker search 命令, 只能经过 http://domain:5000/v2/image_name/tags/list 查看指定镜像存在的 tag 列表

$ curl domain:5000/v2/nginx/tags/list
{"name":"nginx","tags":["latest"]}
复制代码

下载镜像

首先咱们经过 docker rmi 将本地的镜像删除(取消标签)。

$ docker rmi domain:5000/nginx
Untagged: domain:5000/nginx:latest
Untagged: domain:5000/nginx@sha256:066edc156bcada86155fd80ae03667cf3811c499df73815a2b76e43755ebbc76
复制代码

再使用 docker images 确认 domain:5000/nginx 这个镜像在本地不存在,接下来咱们就能够从私有仓库进行下载。

$ docker pull domain:5000/nginx:latest
复制代码

除了使用官方提供的 Registry,咱们也可使用 Nexus3.x 来建立仓库,关于如何使用 Nexus 版本的仓库将放到下一篇文章中。固然你也能够从 https://docker_practice.gitee.io/zh-cn/repository/nexus3_registry.html 学习。


若是你喜欢个人文章,但愿能够关注一下个人公众号【前端develop】

前端develop
相关文章
相关标签/搜索