千家信息网

docker私有仓库如何搭建

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章将为大家详细讲解有关docker私有仓库如何搭建,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。docker-registry的部署查看docker-regi
千家信息网最后更新 2025年01月19日docker私有仓库如何搭建

这篇文章将为大家详细讲解有关docker私有仓库如何搭建,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

docker-registry的部署

查看docker-registry版本信息:

[root@docker-registry ~]# yum info docker-registryLoaded plugins: fastestmirrorLoading mirror speeds from cached hostfile * base: mirror.bit.edu.cn * extras: mirror.bit.edu.cn * updates: mirror.bit.edu.cnAvailable PackagesName        : docker-registryArch        : x86_64Version     : 0.9.1Release     : 7.el7Size        : 123 kRepo        : extras/7/x86_64Summary     : Registry server for DockerURL         : https://github.com/docker/docker-registryLicense     : ASL 2.0Description : Registry server for Docker (hosting/delivering of repositories and images).

安装docker-registry:

[root@docker-registry ~]# yum -y install docker-registry

查看安装后docker-distribution的的配置文件位置

[root@docker-registry ~]# rpm -ql docker-distribution/etc/docker-distribution/registry/config.yml/usr/bin/registry/usr/lib/systemd/system/docker-distribution.service/usr/share/doc/docker-distribution-2.6.2/usr/share/doc/docker-distribution-2.6.2/AUTHORS/usr/share/doc/docker-distribution-2.6.2/CONTRIBUTING.md/usr/share/doc/docker-distribution-2.6.2/LICENSE/usr/share/doc/docker-distribution-2.6.2/MAINTAINERS/usr/share/doc/docker-distribution-2.6.2/README.md/var/lib/registry  #数据放在这个目录下,可以修改/etc/docker-distribution/registry/config.yml改这个路径

查看配置文件:

[root@docker-registry ~]# cat /etc/docker-distribution/registry/config.ymlversion: 0.1log:  fields:    service: registrystorage:    cache:        layerinfo: inmemory    filesystem:        rootdirectory: /var/lib/registry  #镜像存储位置,可以修改成自己的http:    addr: :5000  #监听端口为5000

启动服务:

[root@docker-registry ~]# systemctl start docker-distribution[root@docker-registry ~]# systemctl enable docker-distributionCreated symlink from /etc/systemd/system/multi-user.target.wants/docker-distribution.service to /usr/lib/systemd/system/docker-distribution.service.

这样我们就装好了docker-registry。

下面我们测试,把node3机器上的镜像推到docker-registry机器上。

[root@k8s-node3 ~]# docker imagesREPOSITORY                                    TAG                 IMAGE ID            CREATED             SIZEmysql                                         5.7.22              6bb891430fb6        3 months ago        372 MB

我们准备把node3上的mysql:5.7.22镜像推到docker-registry机器上,需要先给node3机器上的镜像mysql打标签:

[root@k8s-node3 ~]# docker tag mysql:5.7.22 docker-registry:5000/mysql:5.7.22
[root@k8s-node3 ~]#  docker imagesREPOSITORY                                    TAG                 IMAGE ID            CREATED             SIZEdocker-registry.com:5000/mysql                5.7.22              6bb891430fb6        3 months ago        372 MB

注意,docker-registry是主机名,要用hosts文件解析到对应的registryip地址上。

[root@k8s-node3 ~]# docker push docker-registry:5000/mysql:5.7.22The push refers to a repository [docker-registry:5000/mysql]Get https://docker-registry:5000/v1/_ping: http: server gave HTTP response to HTTPS client

注意:如果上面写作docker-registry:5000/mysql,说明推送的是mysql顶级仓库下所有的镜像版本。

上面看到,我们docker push 时报错了,这是因为docker 客户端默认使用的https形式的,但是dockr registry server端是http形式的。

如果我们实在就用http的,那就需要对docker 客户端做如下修改:

[root@k8s-node3 ~]# vim /etc/docker/daemon.json {"registry-mirrors": ["https://registry.docker-cn.com"],"insecure-registries": ["docker-registry:5000"]}

注意,上面的dokcer-registry是主机名。

[root@k8s-node3 ~]# systemctl  restart docker

然后再推就能推上去了。

[root@k8s-node3 ~]# docker push docker-registry:5000/mysql:5.7.22The push refers to a repository [docker-registry:5000/mysql]a968f24d4187: Pushed f8cb294d5d80: Pushed 489bddb9c55e: Pushed 22b402e93939: Pushed 8aeebb3964c1: Pushed 94f8d8f5acbf: Pushed c0c26734fb83: Pushed 4801a487d51a: Pushed aae63f31dee9: Pushed 6f8d38b0e2b6: Pushed cdb3f9544e4c: Pushed 5.7.22: digest: sha256:1d3119703eb04855c971a9ec24646184444fa1bd889b201de3ce8904c35eb627 size: 2621

然后,我们登录到docker registry服务器,就能看到推送过来的镜像了:

[root@docker-registry ~]# ll /var/lib/registry/docker/registry/v2/repositories/mysql/total 0drwxr-xr-x. 3 root root 20 Oct 25 05:13 _layersdrwxr-xr-x. 4 root root 35 Oct 25 05:14 _manifestsdrwxr-xr-x. 2 root root  6 Oct 25 05:14 _uploads

下面我们就让其他服务器从docker-registry服务器上下载镜像。

首先也需要在其他服务器上更改docker配置,加个"insecure-registries"参数,如下:

[root@k8s-node1 ~]# cat /etc/docker/daemon.json {"registry-mirrors": ["https://registry.docker-cn.com"],"insecure-registries": ["docker-registry:5000"]}
[root@k8s-node1 ~]# systemctl restart docker

然后在这个机器上下载docker-registry机器上的镜像:

    [root@k8s-node1 ~]# docker pull docker-registry:5000/mysql:5.7.225.7.22: Pulling from mysql2da35ff30a7d: Pull complete 46459f75a599: Pull complete fe071c86fe94: Pull complete 75457c650197: Pull complete 6506db22c932: Pull complete a6e0a2acd728: Pull complete 3182738b1913: Pull complete ea75bfdf07be: Pull complete 6b85e8810885: Pull complete 5dca51ac89bd: Pull complete b3400d337f49: Pull complete Digest: sha256:1d3119703eb04855c971a9ec24646184444fa1bd889b201de3ce8904c35eb627Status: Downloaded newer image for docker-registry:5000/mysql:5.7.22
[root@k8s-node1 ~]# docker imagesREPOSITORY                                                       TAG                 IMAGE ID            CREATED             SIZEtomcat                                                           latest              05af71dd9251        8 days ago          463 MBdocker-registry:5000/mysql                                       5.7.22              6bb891430fb6        3 months ago        372 MB

看到下载的镜像就是我们私有仓库里面的。

harbor的部署

我们看到上面搭建的docker私有仓库是命令行界面的,很丑陋。不过,好消息是,目前有个开源项目叫harbor,是在docker registry基础上做的,并带了个漂亮的web界面,还支持冗余等。是个非常不错的项目。另外,CNCF组织也非常青睐harbor,可见harbor的前景非常不错。

可是,harbor的部署是非常麻烦的。还好,现在可以用docker compose(单机编排工具)来做harbor的安装。

下面我们准备安装harbor试一下。

官方项目地址是: https://github.com/goharbor/harbor

官方安装文档:https://github.com/goharbor/harbor/blob/master/docs/installation_guide.md

harbor官方要求配置为:

SoftwareVersionDescription
Pythonversion 2.7 or higherNote that you may have to install Python on Linux distributions (Gentoo, Arch) that do not come with a Python interpreter installed by default
Docker engineversion 1.10 or higherFor installation instructions, please refer to: https://docs.docker.com/engine/installation/
Docker Composeversion 1.6.0 or higherFor installation instructions, please refer to: https://docs.docker.com/compose/install/
Openssllatest is preferredGenerate certificate and keys for Harbor

先安装epel源。

[root@harbor yum.repos.d]# cd /etc/yum.repos.d/[root@harbor yum.repos.d]# wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

看epel里面的docker-compose版本情况:

[root@docker-registry yum.repos.d]# yum info docker-composeepel                                                                                                                     12742/12742Available PackagesName        : docker-composeArch        : noarchVersion     : 1.18.0Release     : 1.el7Size        : 226 kRepo        : epel/x86_64Summary     : Multi-container orchestration for DockerURL         : https://github.com/docker/composeLicense     : ASL 2.0

登录 https://github.com/goharbor/harbor/releases下载harbor。

我们下载二进制的安装包:

[root@harbor ~]# wget https://storage.googleapis.com/harbor-releases/harbor-offline-installer-v1.6.1.tgz
[root@harbor ~]# tar -xvf harbor-offline-installer-v1.6.1.tgz  -C /usr/local/

编辑配置文件:

[root@harbor ~]# cd /usr/local/harbor/
[root@docker-registry harbor]# vim harbor.cfghostname = 172.16.22.196 #harbor服务器的名称,可以是IP地址(本机ip),或者是完整的域名,不要使用localhost或者127.0.0.1,因为服务需要被其他的机器访问ui_url_protocol = http  max_job_workers = 10 #小于操作系统的cpu个数harbor_admin_password = Harbor12345 #admin的密码

停止我们前面安装的docker-distribution

[root@harbor harbor]# systemctl stop docker-distribution

安装docker-compose

[root@docker-registry harbor]# yum install docker-compose

安装docker:

[root@harbor harbor]#yum intall docker-ce[root@harbor harbor]# systemctl start docker

安装harbor:

[root@harbor harbor]# ./prepare [root@harbor harbor]# ./install.sh [Step 0]: checking installation environment ...Note: docker version: 18.06.1Note: docker-compose version: 1.18.0

安装过程时间比较长,原因是它需要展开harbor.v1.6.1.tar.gz镜像,并安装这些镜像。

安装完后,访问 http://172.16.22.196,默认用户名admin,密码Harbor12345

登录后,我们建立一个普通用户:

创建一个项目:

备注:上面的复制管理就是用来给harbor做主从复制的。

然后以普通用户登录,并创建一个项目:

我们登录另外一个机器node03当做客户端,然后在这个机器上修改客户端以http方式访问harbor server(我这里ip是172.16.22.196):

[root@k8s-node3 ~]# vim /etc/docker/daemon.json{"registry-mirrors": ["https://registry.docker-cn.com"],"insecure-registries": ["172.16.22.196"]}
[root@k8s-node3 ~]# systemctl daemon-reload[root@k8s-node3 ~]# systemctl restart docker

然后给node3的镜像打标签,打成harbor主机名形式:

[root@k8s-node3 ~]# docker tag mysql:5.7.22  172.16.22.196/dev/mysql:5.7.22

在node3机器上,登录docker-registry(172.16.22.196)

[root@k8s-node3 ~]# docker login 172.16.22.196Username: chenzhixinPassword: Login Succeeded

把node3上的镜像推送到harbor server172.16.22.196上:

[root@k8s-node3 ~]# docker push 172.16.22.196/dev/mysql #不加标签标示把mysql下所有标签的镜像都推送到harbor上The push refers to a repository [172.16.22.196/dev/mysql]a968f24d4187: Pushed f8cb294d5d80: Pushed 489bddb9c55e: Pushed 22b402e93939: Pushed 8aeebb3964c1: Pushed 94f8d8f5acbf: Pushed c0c26734fb83: Pushed 4801a487d51a: Pushed aae63f31dee9: Pushed 6f8d38b0e2b6: Pushed cdb3f9544e4c: Pushed 5.7.22: digest: sha256:1d3119703eb04855c971a9ec24646184444fa1bd889b201de3ce8904c35eb627 size: 2621

然后我们就能在harbor server上看到我们推送的镜像了:

Harbor容器的stop与start:

进入Harbor目录执行如下命令即可:cd /usr/local/harbordocker-compose stop/start

其他补充知识:

/usr/local/harbor/docker-compose.yml :这个文件里面定义了数据存放的目录是:/data

[root@harbor harbor]# ls /data/ca_download  config  database  job_logs  psc  redis  registry  secretkey

关于"docker私有仓库如何搭建"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

0