Linux搭建NexusDocker私有仓库教程
时间:2026-04-15 10:12:33 242浏览 收藏
本文详细介绍了如何在Linux系统中利用Nexus Repository Manager 3快速搭建安全、可控的私有Docker镜像仓库,涵盖从Java 11环境准备、Nexus下载安装与非root用户服务化部署,到Web界面创建Docker Hosted仓库(端口5000)及Docker daemon信任HTTP registry的关键配置,手把手解决企业级镜像管理中的身份认证、权限隔离与协议兼容等实际痛点,助你轻松构建高效稳定的本地容器镜像分发中心。

如果您希望在Linux系统中快速部署一个私有Docker镜像仓库,Nexus Repository Manager 3 提供了对Docker格式的支持,可通过其Docker Hosted类型仓库实现。以下是完成该部署的具体步骤:
一、安装Java运行环境
Nexus 3要求Java 11或更高版本运行,需先确认并安装兼容的JRE/JDK。
1、执行命令检查当前Java版本:java -version
2、若未安装或版本低于11,使用包管理器安装OpenJDK 11:sudo apt update && sudo apt install openjdk-11-jre-headless -y(Ubuntu/Debian)
3、对于CentOS/RHEL系统,运行:sudo yum install java-11-openjdk-headless -y 或 sudo dnf install java-11-openjdk-headless -y
4、设置JAVA_HOME环境变量:echo 'export JAVA_HOME=$(dirname $(dirname $(readlink -f $(which java))))' | sudo tee -a /etc/profile.d/java.sh && source /etc/profile.d/java.sh
二、下载并解压Nexus Repository Manager 3
获取官方发布的Nexus 3二进制分发包,解压至指定目录后即可运行,无需编译或复杂配置。
1、创建安装目录:sudo mkdir -p /opt/nexus
2、进入目录并下载最新OSS版Nexus 3:cd /opt/nexus && sudo wget https://download.sonatype.com/nexus/3/latest-unix.tar.gz
3、解压压缩包:sudo tar -xzf latest-unix.tar.gz --strip-components=1
4、修改Nexus工作目录权限,确保nexus用户可写:sudo chown -R nexus:nexus /opt/nexus
三、创建专用系统用户并配置服务
为安全起见,Nexus不应以root身份运行,需创建独立用户并配置systemd服务实现后台常驻。
1、添加nexus用户并禁止登录:sudo useradd -r -m -U -d /opt/nexus -s /bin/false nexus
2、编辑systemd服务文件:sudo nano /etc/systemd/system/nexus.service
3、填入以下内容(注意路径与用户匹配):[Unit]\nDescription=nexus\nAfter=network.target\n\n[Service]\nType=forking\nLimitNOFILE=65536\nUser=nexus\nGroup=nexus\nExecStart=/opt/nexus/bin/nexus start\nExecStop=/opt/nexus/bin/nexus stop\nRestart=on-failure\n\n[Install]\nWantedBy=multi-user.target
4、重载服务配置并启用启动:sudo systemctl daemon-reload && sudo systemctl enable nexus && sudo systemctl start nexus
四、配置Nexus中的Docker Hosted仓库
启动Nexus后,需通过Web界面新建一个支持Docker协议的Hosted仓库,用于接收和分发私有镜像。
1、等待Nexus启动完成(约60秒),访问:http://:8081
2、首次登录使用默认凭据:admin / admin123,登录后按提示修改密码
3、进入Settings → Repositories → Create repository,选择docker (hosted)
4、填写仓库名称(如:docker-private),勾选HTTP并设置端口为5000,取消勾选“Force basic authentication”
5、点击Create repository完成创建
五、配置Docker守护进程信任HTTP仓库
Docker默认拒绝向非HTTPS的registry推送镜像,需显式配置insecure-registries参数以允许连接到本地Nexus的HTTP Docker仓库。
1、编辑Docker守护进程配置文件:sudo nano /etc/docker/daemon.json
2、添加insecure-registries条目(替换为实际服务器IP):{"insecure-registries":["192.168.1.100:5000"]}
3、重启Docker服务使配置生效:sudo systemctl restart docker
4、验证配置是否加载成功:sudo docker info | grep -A 1 "Insecure Registries"
好了,本文到此结束,带大家了解了《Linux搭建NexusDocker私有仓库教程》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
370 收藏
-
417 收藏
-
237 收藏
-
203 收藏
-
330 收藏
-
396 收藏
-
114 收藏
-
375 收藏
-
347 收藏
-
113 收藏
-
464 收藏
-
258 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习