Docker搭建harbor私有镜像仓库(命令行模式)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 这是安装docker的步骤,可以参考;[linux(centos)中部署docker(步骤超全,含带一些发展史和一些概念)](https://blog.csdn.net/liu_chen_yang/article/details/123842609)启动docker和设置开机自启

@[toc]

一、安装docker

这是安装docker的步骤,可以参考;
linux(centos)中部署docker(步骤超全,含带一些发展史和一些概念)
启动docker和设置开机自启

#启动daemon-reload
systemctl daemon-reload

#启动docker
systemctl start docker

#设置开机自启
systemctl enabel docker

二、搭建harbor镜像仓库

拉取Registry私有镜像仓库,在我们本地搭建一个内网的仓库,避免将一些私密项目暴露在公网,引发不必要的风险

1、下载Registry镜像

docker pull registry

在这里插入图片描述

2、运行Registry镜像并查看

docker run -d --name registry -p 5000:5000 -v /storage/registry:/tmp/registry registry

在这里插入图片描述

3、查看镜像仓库中的所有镜像

curl http://127.0.0.1:5000/v2/_catalog

下图返回的json数据代表有一个仓库,因为我做测试的时候上传了一个镜像。(busybox)
在这里插入图片描述

三、配置仓库可直接通过http方式访问

docker默认是传输方式使用https协议,我们手头上没有https证书,所以此处不配置https证书,直接设置可信源,使我们内网可以通过http方式访问

1、修改vim /etc/docker/daemon.json,添加以下内容

没有daemon.json文件的话,新建一个就好。

    "insecure-registries" :[ 
         "your-server-ip:5000"
    ]

因为我这是已经有了哪个文件,而且里面还有别的,所以,到时候一定要看好格式;
在这里插入图片描述

2、重新加载、重启docker、启动镜像

#重新加载
systemctl daemon-reload
#重启docker
systemctl restart docker
#启动registry容器
docker start registry

四、上传镜像至仓库

1、查看所有镜像

[root@localhost ~]# docker images
REPOSITORY                                  TAG                 IMAGE ID            CREATED             SIZE
mycentos                                    0.0.1               ce509ec398c1        2 days ago          231MB

2、给要上传的镜像tag打个标签(修改镜像名)

格式:

docker tag 镜像名:版本 you-ip:端口/镜像名:版本

实例:

docker tag mycentos:0.0.1 127.0.0.1:5000/mycentos:v1

3、推送镜像到harbor仓库

格式:

docker push 修改的镜像名

实例:

[root@localhost ~]# docker push 127.0.0.1:5000/mycentos:v1
The push refers to repository [127.0.0.1:5000/mycentos]
74ddd0ec08fa: Pushed 
v1: digest: sha256:d8217a445d79fb6325eb26a651d2a7a1ceb7f53c44d82cd7bb9e8fd2bdb384a9 size: 529

这样表示拉取成功。

4、验证是否推送成功

[root@localhost ~]# curl http://127.0.0.1:5000/v2/_catalog
{"repositories":["busybox","mycentos"]}

在这里插入图片描述
这里我们可以看到,多了一个mycentos,这样就是推送成功了,mycentos镜像就已经上传上来了。

五、本地拉取镜像

格式:

docker pull 上传时修改的镜像名

实例:

[root@localhost ~]# docker pull 127.0.0.1:5000/mycentos:v1
v1: Pulling from mycentos
a1d0c7532777: Already exists 
Digest: sha256:d8217a445d79fb6325eb26a651d2a7a1ceb7f53c44d82cd7bb9e8fd2bdb384a9
Status: Downloaded newer image for 127.0.0.1:5000/mycentos:v1
127.0.0.1:5000/mycentos:v1

查看镜像,我们就可以看到已经拉取了。(刚刚的镜像已经删除这是重新从harbor镜像仓库拉的)
在这里插入图片描述
要想改回原来的名字,我们可以给他打标签;

格式:

docker tag 上传时修改的镜像名 现在想改回去的镜像名:版本

实例:

docker tag 127.0.0.1:5000/mycentos:v1 mycentos:v1

这样就改回来了。
在这里插入图片描述

六、客户端(另一台服务器)拉取镜像

另一台客户机也需要docker是前提,注意要配置http方式访问,然后访问下载镜像。

1、1. 修改vim /etc/docker/daemon.json添加以下内容

your-server-ip——你服务端的ip

{ 
    "insecure-registries" :[
         "your-server-ip:5000"
     ] 
}

2、重新加载、重启docker

#重新加载
systemctl daemon-reload
#重启docker
systemctl restart docker

3、拉取镜像

ip要服务端设置的ip,我那边后来有设置了一个同网段的ip,所以现在才可以访问到;

docker pull 192.168.2.22:5000/registry:v1

在这里插入图片描述
这里就可以看到我们已经拉取成功了。
在这里插入图片描述

总结

相关文章:

①、 Docker——denied: requested access to the resource is denied问题以及解决方法
②、 Linux中安装/部署docker-compose
③、 Linux中基于Docker搭建harbor私有镜像仓库(超级详细)🔥🔥
④、 Docker发布/上传镜像到dockerhub&&下载/拉取镜像&&删除dockerhub镜像
相关实践学习
通过容器镜像仓库与容器服务快速部署spring-hello应用
本教程主要讲述如何将本地Java代码程序上传并在云端以容器化的构建、传输和运行。
Kubernetes极速入门
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 本课程从Kubernetes的简介、功能、架构,集群的概念、工具及部署等各个方面进行了详细的讲解及展示,通过对本课程的学习,可以对Kubernetes有一个较为全面的认识,并初步掌握Kubernetes相关的安装部署及使用技巧。本课程由黑马程序员提供。   相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
15天前
|
缓存 Linux 网络安全
docker的镜像无法下载如何解决?
【10月更文挑战第31天】docker的镜像无法下载如何解决?
497 28
|
8天前
|
运维 Linux Docker
安装Harbor镜像仓库
本文介绍了如何在Linux系统上安装和配置Harbor镜像仓库。首先通过阿里云镜像源安装Docker,然后下载并解压Harbor离线安装包。配置Harbor服务的相关参数。最后,通过运行安装脚本完成Harbor的安装,并进行基本的测试,包括登录、构建和推送Docker镜像。文章还提供了相关资源链接,方便读者进一步了解和学习。
25 2
|
11天前
|
存储 关系型数据库 Linux
【赵渝强老师】什么是Docker的镜像
Docker镜像是一个只读模板,包含应用程序及其运行所需的依赖环境。镜像采用分层文件系统,每次修改都会以读写层形式添加到原只读模板上。内核bootfs用于加载Linux内核,根镜像相当于操作系统,上方为应用层。镜像在物理存储上是一系列文件的集合,默认存储路径为“/var/lib/docker”。
|
17天前
|
存储 监控 Linux
docker构建镜像详解!!!
本文回顾了Docker的基本命令和管理技巧,包括容器和镜像的增删改查操作,容器的生命周期管理,以及如何通过端口映射和数据卷实现容器与宿主机之间的网络通信和数据持久化。文章还详细介绍了如何使用Docker部署一个简单的Web应用,并通过数据卷映射实现配置文件和日志的管理。最后,文章总结了如何制作自定义镜像,包括Nginx、Python3和CentOS镜像,以及如何制作私有云盘镜像。
87 2
|
18天前
|
关系型数据库 MySQL Docker
docker环境下mysql镜像启动后权限更改问题的解决
在Docker环境下运行MySQL容器时,权限问题是一个常见的困扰。通过正确设置目录和文件的权限,可以确保MySQL容器顺利启动并正常运行。本文提供了多种解决方案,包括在主机上设置正确的权限、使用Dockerfile和Docker Compose进行配置、在容器启动后手动更改权限以及使用 `init`脚本自动更改权限。根据实际情况选择合适的方法,可以有效解决MySQL容器启动后的权限问题。希望本文对您在Docker环境下运行MySQL容器有所帮助。
33 1
|
11天前
|
Docker 容器
【赵渝强老师】Docker的None网络模式
Docker容器在网络方面实现了逻辑隔离,提供了四种网络模式:bridge、container、host和none。其中,none模式下容器具有独立的网络命名空间,但不包含任何网络配置,仅能通过Local Loopback网卡(localhost或127.0.0.1)进行通信。适用于不希望容器接收任何网络流量或运行无需网络连接的特殊服务。
|
11天前
|
Docker 容器
【赵渝强老师】Docker的Host网络模式
Docker容器在网络环境中是隔离的,可通过配置不同网络模式(如bridge、container、host和none)实现容器间或与宿主机的网络通信。其中,host模式使容器与宿主机共享同一网络命名空间,提高性能但牺牲了网络隔离性。
|
11天前
|
Kubernetes Docker 容器
【赵渝强老师】Docker的Container网络模式
Docker容器在网络环境中彼此隔离,但可通过配置不同网络模式实现容器间通信。其中,container模式使容器共享同一网络命名空间,通过localhost或127.0.0.1互相访问,提高传输效率。本文介绍了container模式的特点及具体示例。
|
11天前
|
Linux Docker 容器
【赵渝强老师】Docker的Bridge网络模式
本文介绍了Docker容器的网络隔离机制及其四种网络模式:bridge、container、host和none。重点讲解了默认的bridge模式,通过示例演示了如何创建自定义bridge网络并配置容器的网络信息。文中还附有相关图片和视频讲解,帮助读者更好地理解Docker网络的配置和使用方法。
|
11天前
|
缓存 JavaScript 安全
深入理解Docker镜像构建过程
深入理解Docker镜像构建过程
42 0