Docker私有部署指南

一、Docker私有部署概述

Docker私有部署指的是在企业内网或私有环境中搭建Docker镜像仓库,用于存储和管理自己构建的Docker镜像。与使用Docker Hub等公共仓库相比,私有部署提供了更好的安全性、可控性和性能。

二、本地打包镜像到内网服务器部署流程

1. 本地构建Docker镜像

首先确保你已经在本地构建好Docker镜像:

bash 复制代码
# 构建镜像(假设你的Dockerfile在当前目录)
docker build -t my-app:1.0 .

2. 在内网服务器上搭建私有仓库(可选)

如果你需要频繁部署多个镜像,建议搭建私有仓库:

方法一:使用Docker Registry(官方方案)

bash 复制代码
# 在内网服务器上运行
docker run -d -p 5000:5000 --restart=always --name registry registry:2

方法二:使用Harbor(企业级方案)

Harbor介绍与搭建并使用教程

Harbor提供了更完善的功能,包括UI界面、权限控制等:

  1. 下载Harbor安装包
  2. 修改harbor.yml配置
  3. 运行安装脚本

3. 将本地镜像推送到私有仓库

如果使用私有仓库:

bash 复制代码
# 标记镜像
# docker tag your-image-name:tag your-server-ip:5000/your-image-name:tag
docker tag my-app:1.0 192.168.1.100:5000/my-app:1.0

# 推送镜像(确保服务器防火墙开放了5000端口)
# docker push your-server-ip:5000/your-image-name:tag
docker push 192.168.1.100:5000/my-app:1.0

如果直接传输到服务器(不使用私有仓库):

bash 复制代码
# 保存镜像为文件
# docker save -o your-image-name.tar your-image-name:tag
docker save -o my-app-1.0.tar my-app:1.0

# 将文件传输到内网服务器(使用scp或其他方式)
# scp your-image-name.tar username@your-server-ip:/path/to/destination/
scp my-app-1.0.tar [email protected]:/home/admin/docker-images/

4. 在内网服务器上加载和运行镜像

如果使用私有仓库:

bash 复制代码
# 从私有仓库拉取
# docker pull your-server-ip:5000/your-image-name:tag
docker pull 192.168.1.100:5000/my-app:1.0

# 运行容器
# docker run -d -p host-port:container-port your-server-ip:5000/your-image-name:tag
docker run -d -p 8081:8080 192.168.1.100:5000/my-app:1.0

如果直接传输了镜像文件:

bash 复制代码
# 在服务器上加载镜像
# docker load -i your-image-name.tar
docker load -i /home/admin/docker-images/my-app-1.0.tar

# 运行容器
# docker run -d -p host-port:container-port your-image-name:tag
docker run -d -p 8081:8080 my-app:1.0

三、常见问题解决

  1. HTTP仓库问题:如果使用非HTTPS仓库,需在客户端Docker配置中添加:
bash 复制代码
 # 在/etc/docker/daemon.json中添加(示例IP:192.168.1.100)
{
  "insecure-registries": ["192.168.1.100:5000"]
}
# 然后重启docker服务
sudo systemctl restart docker
  1. 权限问题:Harbor等仓库需要先登录:
bash 复制代码
# 登录私有仓库示例(用户admin,密码123456)
docker login 192.168.1.100:5000 -u admin -p 123456
  1. 存储空间 :私有仓库默认存储在/var/lib/registry,确保有足够空间
bash 复制代码
# 查看私有仓库存储使用情况(假设仓库容器名为my-private-registry)
docker exec -it my-private-registry du -sh /var/lib/registry

四、进阶建议

  1. 使用CI/CD工具自动化构建和部署流程
bash 复制代码
    # Jenkins示例构建命令
    docker build -t ${JOB_NAME}:${BUILD_NUMBER} .
    docker tag ${JOB_NAME}:${BUILD_NUMBER} 192.168.1.100:5000/${JOB_NAME}:${BUILD_NUMBER}
    docker push 192.168.1.100:5000/${JOB_NAME}:${BUILD_NUMBER}
  1. 为镜像打上有意义的标签(如版本号、构建日期)
bash 复制代码
    # 使用版本号+构建日期
    docker build -t my-app:1.0-$(date +%Y%m%d) .
  1. 定期清理旧镜像释放空间
bash 复制代码
    # 删除7天前的镜像
    docker images --format "{{.ID}} {{.CreatedSince}}" | grep "weeks ago" | awk '{print $1}' | xargs docker rmi
相关推荐
撸码到无法自拔5 小时前
docker常见命令
java·spring cloud·docker·容器·eureka
hi,编程哥9 小时前
Docker、ECS 与 K8s 网段冲突:解决跨服务通信中的路由问题
docker·容器·kubernetes
How_doyou_do10 小时前
项目全栈实战-基于智能体、工作流、API模块化Docker集成的创业分析平台
运维·docker·容器
xbd_zc14 小时前
【Jenkins简单自动化部署案例:基于Docker和Harbor的自动化部署流程记录】
docker·自动化·jenkins·harbor
我的璨宝宝啊15 小时前
linux小主机搭建自己的nas(三)docker安装nextcloud
linux·运维·docker
大米☋15 小时前
GitLab搭建与使用(SSH和Docker)两种方式
docker·ssh·gitlab
污斑兔17 小时前
在Mac环境下搭建Docker环境的全攻略
docker
modest —YBW17 小时前
Ollama+OpenWebUI+docker完整版部署,附带软件下载链接,配置+中文汉化+docker源,适合内网部署,可以局域网使用
人工智能·windows·docker·语言模型·llama
心动啊12118 小时前
docker使用过程中遇到概念问题
运维·docker·容器
Penguido19 小时前
基于 Nexus 在 Dockerfile 配置 yum, conda, pip 仓库的方法和参考
linux·docker·centos·conda·pip