docker:搭建私有仓库

2023-12-13 04:55:30

1、拉取镜像

docker pull registry

2、运行容器

docker run -di --name=registry -p 5000:5000 registry

3、测试成功

打开浏览器 输入地址 http://localhost:5000/v2/_catalog看到 {"repositories":[]} 表示私有仓库搭建成功并且内容为空
在这里插入图片描述
我这里用 5001 是宿主机端口被占用了,你就用 5000

4、修改daemon.json

注意:这个文件是宿主机上的文件,不是某个镜像内部的文件

vi /etc/docker/daemon.json
{"insecure-registries":["192.168.184.141:5000"]}

此步用于让 docker信任私有仓库地址

  • 在大多数 Linux 发行版上,Docker 守护进程的配置文件通常位于 /etc/docker/daemon.json。

  • 在 Windows 上,默认情况下 Docker 守护进程的配置文件通常位于 C:\ProgramData\Docker\config\daemon.json。

  • 在 macOS 上, Docker Desktop for Mac 中,并不直接使用 daemon.json 文件,因为 Docker Desktop for Mac 使用了一个虚拟的 Linux 虚拟机(HyperKit)来运行 Docker 守护进程。
    在 Docker Desktop for Mac 中,你可以通过点击 Docker Desktop 应用图标,然后选择 “Preferences” -> “Docker Engine” 选项来进行配置。这样你就可以看到一个 JSON 配置文件编辑器,可以直接在界面上进行编辑 Docker 守护进程的配置。
    在这里插入图片描述

请注意,如果配置文件不存在,你可以手动创建它。

{
  "insecure-registries": ["your-registry-domain-or-ip:5000"]
}

5、重启docker 服务

# centos
systemctl restart docker

如果是 mac 使用 Docker Desktop 重启

6、上传镜像到私有仓库

6.1 标记某个镜像为私有仓库镜像

这里标记 jdk1.8 这个镜像为仓库镜像

cd jdk1.8所在目录
docker tag jdk1.8 localhost:5000/jdk1.8

6.2 上传镜像到私有仓库

docker push 192.168.184.141:5000/jdk1.8

其他注意项

/etc/docker/registry/config.yml

该文件是 Docker 镜像仓库 Registry 的配置文件。Registry 是一个用于存储和管理 Docker 镜像的服务,可以用作公共 Registry 或者私有 Registry。

在这个配置文件中,你可以定义一些 Registry 的行为和属性,例如镜像存储的位置、使用的存储后端、是否启用身份验证等。

以下是一个简单的 config.yml 文件示例:

version: 0.1
log:
  fields:
    service: registry
storage:
  filesystem:
    rootdirectory: /var/lib/registry
http:
  addr: :5000
  headers:
    X-Content-Type-Options: [nosniff]

  • storage 部分定义了 Registry 使用的存储后端,这里是 filesystem,并指定了存储的根目录。
  • http 部分定义了 Registry 的 HTTP 配置,包括监听的地址和端口。

请注意,具体的配置文件内容可能因 Registry 的版本和配置而有所不同。在生产环境中,你可能需要根据实际需求对配置文件进行更详细的配置,包括添加 SSL/TLS 支持、启用身份验证、限制访问等。

如果你对 Registry 的配置进行更改,通常需要重启 Registry 服务以使更改生效。在配置文件被修改后,可以通过以下方式重启 Registry:

sudo systemctl restart docker

文章来源:https://blog.csdn.net/weixin_43972437/article/details/134871285
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。