news 2026/4/18 10:56:05

使用nexus3搭建自己的制品服务器

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用nexus3搭建自己的制品服务器

使用nexus3搭建自己的制品服务器

需求

云原生开发,有个新的需求,就是docker制品服务器,对于私域的开发,公有云的服务器不合适,只能自己搭建了。

所以记录一下搭建一个docker镜像服务器的过程,完成的功能如下:

  1. 存储私有的docker制品,所有有上传下载功能(pull,push)
  2. 代理开源的共有源镜像(dockerhub)
  3. 读写权限分开

使用nexus3大家私服过程

nexus3是目前最全面的私服软件了,支持apt、npm、docker、cargo、go、maven、composer……
这次只使用其docker功能。

使用docker搭建nexus3,并使用caddy作为代理:
nexus3的配置:

services:nexus3:image:sonatype/nexus3:latestcontainer_name:nexus3environment:-TZ=Asia/Shanghai-INSTALL4J_ADD_VM_PARAMS="-Xms2703m-Xmx4G-XX:MaxDirectMemorySize=2703m-Djava.util.prefs.userRoot=/userroot"-NEXUS_CONTEXT=nexusvolumes:-./data:/nexus-data-./userroot:/userrootrestart:alwaysnetworks:default:external:trueenable_ipv6:falsename:netproxy

caddy的配置:

services:caddy:image:caddy:2restart:unless-stoppedcontainer_name:caddycap_add:-NET_ADMINenvironment:-TZ=Asia/Shanghaiports:-"80:80"-"8080:8080"-"443:443"-"443:443/udp"-"1443:1443"-"1443:1443/udp"volumes:-$PWD/conf:/etc/caddy-$PWD/site:/srv-$PWD/config:/config-$PWD/data:/datanetworks:-netproxynetworks:netproxy:name:netproxydriver:bridge

caddy配置文件:

{email Little-baby@163.com acme_ca https://acme.zerossl.com/v2/DV90}nexus.aaa.bbb{redir / /nexus 301 reverse_proxy nexus3:8081encode gzip header Cache-Control "public,max-age=3600" header{Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" X-Content-Type-Options "nosniff" X-XSS-Protection "1; mode=block"}}docker.aaa.bbb:1443{reverse_proxy nexus3:8082}docker.aaa.bbb{reverse_proxy nexus3:8084}

搭建支持上传下载的docker私服

nexus3第一次启动后,需要修改密码,如下图:

修改密码后,后续会提示是否开通匿名访问,关闭。

新建一个host的docker repository

目录: settings->repository->create repository

新建一个支持上传下载的角色和用户
  1. 新建角色

并且赋权刚刚创建的host仓库给这个角色。

  1. 新建用户

新建用户,并且赋角色

  1. security realms

安全配置:

验证读写

# docker 登录dockerlogin docker.aaa.bbb:1443-udwrite# 测试上传dockertag caddy:2 docker.aaa.bbb:1443/myimage:2dockerpush docker.aaa.bbb:1443/myimage:2

上传后就可以看到上传的镜像:

搭建dockerhub 代理

代理dockerhub:

修改端口、索引:

设置清理措施:

代理镜像位于dockerhub,代理服务器只需要缓存,并不需要长久存储,指定一个释放策略可以减少服务器硬盘占用。

创建清理策略:

给代理仓库加载清理策略:

搭建融合镜像

仓库组,用来合并多个hosted/proxy仓库,即将私服和公开的hub代理,合并为一个,方便使用:

设置合并的仓库,并设置顺序,host在前,代理在后:

新建一个新只读角色、只读用户,赋权限,所有仓库的只读权限:

角色:

用户:

权限:

测试
  1. 拉取一个私服里面的镜像
  2. 拉取一个dockerhub里面的镜像
# 登录dockerlogin docker.aaa.bbb-udread# 拉取私服的镜像dockerrmi docker.aaa.bbb/myimage:2# 拉取dockerhub的镜像dockerpull docker.aaa.bbb/alpine

查看,dockerhu的也会被缓存下来:

学习小结:

至此,一个可用的权限分离的docker私服就实现了。nexus3一共有4个服务端口:

8081:可以通过http访问nexus应用
8082:docker(hosted)私有仓库,可以pull和push
8083:docker(proxy) 代理dockerhub,只能pull
8084:docker(group) 私有仓库和代理的组,只能pull

nexus3还有很多的私服功能,下次再开发_

微信公众号:
使用nexus3搭建自己的制品服务器

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 11:02:11

PCB打板是否需要SMT贴片?——从工程实战角度看清本质

在实际研发中,“PCB打板要不要顺带做SMT贴片”几乎是每个硬件工程师都会反复纠结的问题。有人坚持“先手焊,能省就省”,也有人认为“第一次打样就要按量产来”。这两种观点本身都没有错,真正的问题在于:你这一次打板&a…

作者头像 李华
网站建设 2026/4/18 6:41:53

31、Linux 系统下的声音文件编辑与磁盘存储实用指南

Linux 系统下的声音文件编辑与磁盘存储实用指南 在 Linux 系统中,声音文件的编辑和磁盘存储是常见的操作需求。下面将详细介绍声音文件编辑的相关工具和方法,以及磁盘存储的管理技巧。 声音文件编辑 1. 混合声音文件 在 Snd 中,若要将不同音频文件混合成多轨,可以从文件…

作者头像 李华
网站建设 2026/4/17 16:53:03

TensorRT-LLM如何降低云GPU推理成本60%

TensorRT-LLM实战:如何将云GPU推理成本降低60%以上 在大模型落地如火如荼的今天,一个现实问题正困扰着无数企业——为什么我们花了几万美元部署的大模型,实际利用率却不到40%? IDC 2025年Q1发布的《生成式AI基础设施白皮书》指出&…

作者头像 李华
网站建设 2026/4/18 10:40:54

37、Linux 通信与邮件使用指南

Linux 通信与邮件使用指南 在 Linux 系统中,通信和邮件功能是日常使用中非常重要的部分。本文将详细介绍如何在 Linux 系统中进行传真接收、自动接收传真、传真格式转换、使用调制解调器拨号以及电子邮件的发送、接收和管理等操作。 传真接收 在 Linux 中,可以使用 efax …

作者头像 李华
网站建设 2026/4/16 15:46:46

43、Linux系统使用与管理全解析

Linux系统使用与管理全解析 在Linux系统的使用和管理过程中,我们会遇到各种各样的问题,下面将为大家详细介绍一些常见操作和相关知识。 1. 脚本中Perl路径的调整 在执行脚本时,脚本开头的路径可能需要根据实际情况进行调整。例如,一个脚本可能以如下行开头: #!/usr/l…

作者头像 李华