基于Docker搭建Maven私服仓库(Linux)详细教程

文章目录

  • [1. 下载镜像并启动容器](#1. 下载镜像并启动容器)
  • [2. 配置Nexus](#2. 配置Nexus)
  • [3. 配置本地Maven仓库](#3. 配置本地Maven仓库)

1. 下载镜像并启动容器

  • 下载Nexus3镜像

    docker pull sonatype/nexus3

  • 查看Nexus3镜像是否下载成功

    docker images

  • 创建Nexus3的挂载文件夹

    mkdir /usr/local/nexus-data && chown -R 200 /usr/local/nexus-data

  • 启动Nexus3容器

    docker run -d -p 8081:8081 --name nexus -v /usr/local/nexus-data:/nexus-data --restart=always sonatype/nexus3

  • 查看Nexus3容器启动状态

    docker ps

2. 配置Nexus

  • 打开浏览器,访问docker服务器的8081端口
  • 登录Nexus管理员账号,点击页面右上方的登录按钮,提示我们的初始密码保存的位置,到服务器打开该文件,查看密码,然后输入账号密码,登录;
  • 登录后如下图:
  • 进入下一步,设置密码;然后如下图:
  • 配置阿里云代理仓库,由于默认的maven中央仓库访问很慢,因此我们要自己新建一个仓库,并将其代理地址设置为阿里云的地址;
  • 点击创建仓库按钮后,选择仓库类型,我们选择maven2(proxy);
  • 然后配置仓库参数,主要设置其名字和代理URL: Name: aliyun-central; Remote storage: http://maven.aliyun.com/nexus/content/groups/public;

  • 配置仓库组;接下来,需要将aliyun-central配置到仓库组,并且将aliyun-central排在maven-central上面。具体步骤如下所示:
    • 在Repositories列表中,点击maven-public
    • 进入配置后,在最下方将aliyun-central添加到右侧,然后将其移动到最上方的位置后保存;
  • 创建用户;在Security菜单中,点击User菜单,点击添加用户按钮:
  • 添加完成后保存即可;

3. 配置本地Maven仓库

  • 复制setting.xml文件为setting-nexus.xml文件;
  • 配置servers节点: 在settings-binghe.xml文件中,找到servers节点,在servers节点中,配置创建的用户;

    复制代码
      <server>
        <id>nexus</id>
        <username>username</username>
        <password>password/</password>
      </server>
  • 配置本地仓库镜像:

    复制代码
        <mirror>
          <id>central</id>
          <name>Local Repository</name>
          <url>http://192.168.13.196:8081/repository/maven-public</url>
          <mirrorOf>*</mirrorOf>
        </mirror>
  • 配置profiles节点;

    复制代码
          <repositories>
              <repository>
                  <id>nexus-public</id>
                  <url>http://192.168.13.196:8081/repository/maven-public/</url>
                  <releases>
                      <enabled>true</enabled>
                      <updatePolicy>always</updatePolicy>
                  </releases>
                  <snapshots>
                      <enabled>true</enabled>
                      <updatePolicy>always</updatePolicy>
                  </snapshots>
              </repository>
          </repositories>

完成搭建。

相关推荐
ACMer_CTGU1 分钟前
解决报错curl: (35) OpenSSL SSL_connect: 连接被对方重设 in connection to download.docker.com:443
网络协议·docker·ssl
\xin2 分钟前
SQL 注入、文件上传绕过、MySQL UDF 提权、SUID 提权、Docker 逃逸,以及 APT 持久化技术渗透测试全流程第二次思路
sql·mysql·docker·容器·渗透测试·json·漏洞
羑悻的小杀马特4 分钟前
零成本神器组合:用Docker+Uptime Kuma+cpolar打造永不掉线的远程监控系统!
运维·人工智能·docker·容器
禁默5 分钟前
Portainer:让 Docker 管理变简单,用cpolar突破局域网后协作更轻松
java·docker·容器·cpolar
StevenZeng学堂7 分钟前
一文读懂K8S的PV和PVC以及实践攻略
运维·docker·云原生·容器·kubernetes·云计算·go
Bruce-li__7 分钟前
2025保姆级Docker教程------一篇学会使用docker
运维·docker·容器
龙域集团11 分钟前
使用最新宝塔面板安装青龙面板(Docker 版)
服务器·docker·容器
Source.Liu33 分钟前
【Ubuntu】关机重启命令
linux·运维·ubuntu
iCode50433 分钟前
CentOS Stream 9修改静态IP
linux·tcp/ip·centos
Hi202402171 小时前
如何在Docker容器里“克隆自己”
运维·docker·容器