【八】docker私有化镜像仓库部署

docker私有化镜像仓库部署

部署docker仓库,并添加http访问认证

为 Registry 添加 HTTP 基本认证

创建 htpasswd 认证文件

bash 复制代码
# 1. 安装 htpasswd 工具(如果没有)
sudo apt update && sudo apt install apache2-utils -y

# 2. 创建认证文件存放目录
mkdir -p ~/DockerRegistry/auth

# 3. 创建用户(替换 your-username 和 your-password)
htpasswd -Bbn your-username your-password > ~/DockerRegistry/auth/htpasswd

# 4. 添加更多用户(可选)
htpasswd -Bbn another-user another-password >> ~/DockerRegistry/auth/htpasswd

# 5. 查看已创建的用户
cat ~/DockerRegistry/auth/htpasswd

docker-compose.yml编排文件

yml 复制代码
version: '3.8'

services:
  registry-server:
    image: registry:2.8.2
    container_name: docker-registry
    restart: always
    ports:
      - "5000:5000"
    volumes:
      - ./registry-data:/var/lib/registry
      - ./auth:/auth
    environment:
      # 仅需启用删除功能,无需任何CORS配置
      - REGISTRY_STORAGE_DELETE_ENABLED=true
      # 启用 htpasswd 认证
      - REGISTRY_AUTH=htpasswd
      - REGISTRY_AUTH_HTPASSWD_REALM="Registry Realm"
      - REGISTRY_AUTH_HTPASSWD_PATH=/auth/htpasswd
 
  registry-ui:
    image: joxit/docker-registry-ui:main
    container_name: docker-registry-ui
    restart: always
    ports:
      - "8888:80"
    environment:
      # 关键:启用代理模式,UI将作为Registry的反向代理
      - SINGLE_REGISTRY=true
      - REGISTRY_TITLE=My Private Docker Registry
      - DELETE_IMAGES=true
      # 指向Registry服务,UI会代理此地址
      - NGINX_PROXY_PASS_URL=http://registry-server:5000
    depends_on:
      - registry-server

UI 界面如何使用认证

(1)登录:http://192.168.11.103:8888/ 弹窗提醒输入账号密码即可

(2)或者修改 UI 的环境变量,让它自动携带认证信息

yml 复制代码
registry-ui:
  image: joxit/docker-registry-ui:main
  container_name: docker-registry-ui
  restart: always
  ports:
    - "8080:80"
  environment:
    - SINGLE_REGISTRY=true
    - REGISTRY_TITLE=My Private Docker Registry
    - DELETE_IMAGES=true
    - NGINX_PROXY_PASS_URL=http://registry-server:5000
    # 添加认证信息(注意:密码会明文存在于环境变量中)
    - REGISTRY_USERNAME=your-username
    - REGISTRY_PASSWORD=your-password
  depends_on:
    - registry-server

客户端使用方式

配置 insecure-registries

由于使用的是 HTTP 而非 HTTPS,Docker 客户端需要配置信任:

Linux下:

bash 复制代码
sudo nano /etc/docker/daemon.json
bash 复制代码
{
    "registry-mirrors": [
        "https://ghcr.nju.edu.cn",
        "https://docker.1ms.run"
    ],
    "runtimes": {
        "nvidia": {
            "args": [],
            "path": "nvidia-container-runtime"
        }
    },
    "insecure-registries": ["localhost:5000","192.168.11.103:8888","localhost:8888"]

}

window下:

配置之后重启docker

sudo systemctl restart docker

操作镜像

bash 复制代码
# 1. 登录(会提示输入密码)
docker login 192.168.11.103:8888
# 输入用户名: xxx
# 输入密码: xxxxx

# 2. 推送镜像
docker tag ghcr.io/open-webui/open-webui:v0.8.12-cuda   192.168.11.103:8888/open-webui:v0.8.12-cuda
docker push 192.168.11.103:8888/open-webui:v0.8.12-cuda

# 3. 拉取镜像
docker pull 192.168.11.103:8888/open-webui:v0.8.12-cuda

# 4. 登出(可选)
docker logout 192.168.11.103:8888
相关推荐
三十..1 天前
Ceph分布式存储核心技术精要与运维实践指南
运维·分布式·ceph
tianyuanwo1 天前
Jenkins × Gerrit 集成:自动触发构建的全流程解析
运维·servlet·jenkins
IT策士1 天前
Docker从0到1再到 Kubernetes 实战:第15篇Compose 中的服务依赖、健康检查与启动顺序
docker·容器·kubernetes
Waay1 天前
K8s Deployment 滚动更新与回滚深度详解(含踩坑实录+生产选型原理)
云原生·容器·kubernetes
“码”力全开1 天前
深度解析:基于 Docker 与边缘计算的 AI 视频管理平台架构——打通 GB28181/RTSP 协议与“源码交付”的高效集成方案
人工智能·docker·边缘计算
顾默@1 天前
双系统Ubuntu18.04升级22.04,安装docker进行openclaw安装
运维·docker·容器
木卫二号Coding1 天前
打包容器有两种方式
docker
杨充1 天前
1.1 数据编码设计原理
linux·运维·网络·底层原理·数据编码
一只鹿鹿鹿1 天前
信息化项目管理规范(参考Word文件)
java·大数据·运维·开发语言·数据库
wanhengidc1 天前
双线服务器有哪些优点?
运维·服务器