zoukankan      html  css  js  c++  java
  • docker19.03搭建私有容器仓库

    一,启动docker后,搜索registry

    [root@localhost source]# systemctl start docker
    [root@localhost source]# docker search registry
    NAME                                 DESCRIPTION                                     STARS               OFFICIAL            AUTOMATED
    registry                             The Docker Registry 2.0 implementation for s…   2873                [OK]      

    说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/architectforest

             对应的源码可以访问这里获取: https://github.com/liuhongdi/

     说明:作者:刘宏缔 邮箱: 371125307@qq.com

    二,下载registry容器

    1,下载

    [root@localhost docker]# docker pull registry

    2,查看本地的镜像:

    [root@localhost docker]# docker images
    REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
    registry            latest              708bc6af7e5e        6 weeks ago         25.8MB

    三,启动registry

    1,启动registry

    [root@localhost docker]# docker run -d -p 5000:5000 -v /data/docker/registry:/var/lib/registry --privileged=true --restart=always --name registry registry:latest
    0e48cc6c0871bf2d5a0ee0208d3e87ae0cf4706dada93c7e80133fa22f7bbaef
    [root@localhost docker]# docker ps -a
    CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
    0e48cc6c0871        registry:latest     "/entrypoint.sh /etc…"   7 seconds ago       Up 5 seconds        0.0.0.0:5000->5000/tcp   registry

    2,查看registry的ip地址

    [root@localhost docker]# docker inspect registry | grep IPAddress
                "SecondaryIPAddresses": null,
                "IPAddress": "172.17.0.2",
                        "IPAddress": "172.17.0.2",

    3,用浏览器访问5000端口,判断是否安装成功:

    这个地址:

    http://172.17.0.2:5000/v2/

    四,查看私有库的镜像列表:

    [root@localhost docker]# curl http://172.17.0.2:5000/v2/_catalog
    {"repositories":[]}

    五,我们制作一个基于centos8的nfs的镜像

    参见:

    docker19.03制作一个基于centos8的带有nfs4服务的镜像
    地址:https://www.cnblogs.com/architectforest/p/12495958.html

    六,上传一个镜像到私有库

    我们把上面制作的镜像上传到我们搭建的私有库

    1,给当前镜像打上tag:

    [root@localhost ~]# docker tag nfsnginx:0.1 172.17.0.2:5000/nfsnginx:0.1

    查看打tag后的效果

    [root@localhost ~]# docker images | grep nfsnginx
    172.17.0.2:5000/nfsnginx   0.1                 fa72df9fb744        3 hours ago         328MB
    nfsnginx                   0.1                 fa72df9fb744        3 hours ago         328MB

    2,开始push

    [root@localhost ~]# docker push 172.17.0.2:5000/nfsnginx:0.1
    The push refers to repository [172.17.0.2:5000/nfsnginx]
    Get https://172.17.0.2:5000/v2/: http: server gave HTTP response to HTTPS client

    这个报错是什么?

    Docker与Docker Registry交互默认使用https协议,

    我们搭建的Docker Registry只提供http服务,

    当和Registry私有仓库交互时会失败,

    为解决这个问题,我们启动Docker时配置Registry不安全选项即可

    说明:要用防火墙限制私有库的访问,不允许端口从公网上随便访问

    3,解决上面的那个报错:

    [root@localhost ~]# vi /etc/docker/daemon.json

    增加一行:

    "insecure-registries":["172.17.0.2:5000"]

    看例子:

    [root@localhost ~]# more /etc/docker/daemon.json 
    {
        "registry-mirrors":["https://o3trwnyj.mirror.aliyuncs.com"],
        "insecure-registries":["172.17.0.2:5000"]
    }

    然后重启docker服务:

    [root@localhost ~]# systemctl restart docker

    并再次启动容器

    [root@localhost ~]# docker start registry
    registry

    4,再次push:

    [root@localhost ~]# docker push 172.17.0.2:5000/nfsnginx:0.1
    The push refers to repository [172.17.0.2:5000/nfsnginx]
    28dd39094cf0: Pushed 
    0683de282177: Pushed 
    0.1: digest: sha256:98417504960cfd0c3ddbb61f18ac8ed7e4737136cc8640f1d24c0f8f5d4eb1fe size: 741

    5,上传是否成功?我们从浏览器访问这个地址:

    http://172.17.0.2:5000/v2/_catalog

    响应内容为:

    {"repositories":["nfsnginx"]}

    可以确认已上传成功

    6,查看已上传镜像的tag列表:

    从浏览器访问这个地址:

    http://172.17.0.2:5000/v2/nfsnginx/tags/list

    说明:nfsnginx是我们所上传的镜像的名字

    七,从私有库下载一个镜像

    从另一台安装有docker的服务器上测试:

    1,执行docker的pull命令:

    [root@localhost liuhongdi]# docker pull 192.168.1.8:5000/nfsnginx:0.1
    Error response from daemon: Get https://192.168.1.8:5000/v2/: http: server gave HTTP response to HTTPS client

    说明:192.168.1.8是上面搭建registry的docker宿主机的ip

    2,解决方法同上:

    [root@localhost liuhongdi]# vi /etc/docker/daemon.json

    增加一行:

    "insecure-registries":["192.168.1.8:5000"]

    然后重启docker:

    [root@localhost liuhongdi]# systemctl restart docker

    3,再次测试:

    [root@localhost liuhongdi]# docker pull 192.168.1.8:5000/nfsnginx:0.1
    0.1: Pulling from nfsnginx
    8a29a15cefae: Already exists 
    b3f2d668510c: Pull complete 
    Digest: sha256:98417504960cfd0c3ddbb61f18ac8ed7e4737136cc8640f1d24c0f8f5d4eb1fe
    Status: Downloaded newer image for 192.168.1.8:5000/nfsnginx:0.1

    4,查看下载是否成功

    [root@localhost liuhongdi]# docker images | grep nfsnginx
    192.168.1.8:5000/nfsnginx   0.1                 fa72df9fb744        4 hours ago         328MB

     八,查看docker的版本 

    [root@localhost source]# docker --version
    Docker version 19.03.7, build 7141c19
  • 相关阅读:
    P2676 超级书架
    P2955 [USACO09OCT]奇数偶数Even? Odd?
    P1554 梦中的统计
    P2614 计算器弹琴
    4246 奶牛的身高
    Render2
    @viewChild
    querySelector
    ionic4封装样式原理
    事件委托和事件冒泡
  • 原文地址:https://www.cnblogs.com/architectforest/p/12496007.html
Copyright © 2011-2022 走看看