news 2026/6/23 9:03:46

使用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/6/23 13:43:34

38、Linux 邮件与网页浏览实用指南

Linux 邮件与网页浏览实用指南 在 Linux 系统中,邮件管理和网页浏览是日常使用中非常重要的功能。下面将详细介绍相关的工具和操作方法。 邮件管理 查看邮件文件夹 可以使用 less 查看邮件文件夹,也能在文本编辑器中编辑。不过,文件夹会显示为一个包含所有邮件的长滚动…

作者头像 李华
网站建设 2026/6/22 21:24:52

41、互联网服务实用指南

互联网服务实用指南 在互联网的使用过程中,我们常常会涉及到文件传输、新闻阅读、系统和用户活动查询以及消息发送等操作。下面将为大家详细介绍这些操作的相关知识和具体方法。 1. 文件传输 在进行文件传输时,FTP(文件传输协议)是常用的工具。默认情况下,本地系统的当…

作者头像 李华
网站建设 2026/6/23 17:36:18

LLaMA-Factory微调与模型中断续训实战

LLaMA-Factory微调与模型中断续训实战 在大语言模型(LLM)日益渗透到企业服务、智能客服和垂直领域应用的今天,如何高效地对开源模型进行定制化训练,已成为开发者构建专属AI能力的关键一步。面对动辄数十GB的模型参数和复杂的分布…

作者头像 李华
网站建设 2026/6/23 2:16:10

GitHub项目实践:Fork并定制你的个性化Anything-LLM前端界面

GitHub项目实践:Fork并定制你的个性化Anything-LLM前端界面 在智能应用开发的浪潮中,如何让大语言模型(LLM)走出命令行、真正融入用户的日常操作体验?这不仅是技术挑战,更是产品思维的跃迁。一个直观、流畅…

作者头像 李华
网站建设 2026/6/23 17:37:40

pythonstudy Day37

MLP神经网络的训练 PyTorch的安装 我们后续完成深度学习项目中,主要使用的包为pytorch,所以需要安装,你需要去配置一个新的环境。 未来在复现具体项目时候,新环境命名最好是python版本_pytorch版本_cuda版本,例如 p…

作者头像 李华
网站建设 2026/6/23 17:35:43

Linly-Talker结合RAG技术实现知识增强型虚拟客服系统

Linly-Talker结合RAG技术实现知识增强型虚拟客服系统 在银行的智能柜台前,一位老人轻声问:“我这个月养老金涨了多少?”屏幕中的虚拟柜员微微一笑,眼神温和地回应:“根据您所在城市的最新政策,2024年起基础…

作者头像 李华