配置Maven私服

Nexus 是“开箱即用”的系统,不需要数据库,它使用文件系统加 Lucene 来组织数据,支持 WebDAV 与 LDAP 安全身份认证。Nexus 还提供了强大的仓库管理功能,构件搜索功能,它基于 REST,友好的 UI 是一个 extjs 的 REST 客户端,它占用较少的内存,基于简单文件系统而非数据库。Nexus 极大地简化了本地内部仓库的维护和外部仓库的访问。另外,Nexus 还可以在代理远程仓库的同时维护本地仓库,以降低中央仓库的负荷,节省外网带宽和时间。

本篇 Nexus 选择 3.x 版本,Nexus3.x 相较 2.x 版本有很大的改变:

1)从底层重构,从而提高性能,增强扩展能力,并改善用户体验
2)升级界面,增加更多的浏览,搜索和管理功能
3)提供安装包,使部署更简单(安装完自动添加成服务,省去手动添加的麻烦)
4)增加 Docker,NuGet,npm,Bower的支持
5)提供新的管理接口,从而能自动管理任务。
注意:3.x版本只能运行在JVM8及以上

总之,本地内部仓库在本地构建nexus私服的好处有:

1)加速构建、稳定;
2)节省带宽、节省中央maven仓库的带宽;
3)控制和审计;
4)能够部署第三方构件;
5)可以建立本地内部仓库、可以建立公共仓库

这些优点使得Nexus日趋成为最流行的Maven仓库管理器。

 

1.Linux下安装Nexus3.x
这里 Linux 选用 CentOS7.2(已经安装 jdk1.8及以上)。

# wget -P /usr/local http://sonatype-download.global.ssl.fastly.net/nexus/3/nexus-3.6.0-02-unix.tar.gz
1
可能下载比较慢,也可以先下载下来然后上传到 Linux 的 /usr/local 目录,下面来看 Nexus 的源码安装方式:

# cd /usr/local
# mkdir nexus
# tar -zxvf nexus-3.6.0-02-unix.tar.gz -C nexus //解压缩到nexus文件夹(其中包含nexus-3.6.0-02和sonatype-work)

# cd nexus
# mv nexus-3.6.0-02/ nexus

自定义配置虚拟机可打开 nexus.vmoptions 文件进行配置(如果Linux硬件配置比较低的话,建议修改为合适的大小,否则会出现运行崩溃的现象):

# vim nexus/bin/nexus.vmoptions //虚拟机选项配置文件
1
启动 Nexus(默认端口是8081),Nexus 常用的一些命令包括:/usr/local/nexus/nexus/bin/nexus {start|stop|run|run-redirect|status|restart|force-reload},下面我们启动Nexus:

# /usr/local/nexus/nexus/bin/nexus start //启动后稍等会儿才能正常访问
WARNING: ************************************************************
WARNING: Detected execution as "root" user. This is NOT recommended!
WARNING: ************************************************************
Starting nexus

上面在启动过程中出现警告:“不推荐使用root用户启动”。这个警告不影响Nexus的正常访问和使用。去掉上面WARNING的办法请自行百度。
到此安装完毕。下面访问服务器 192.168.2.20:8081,可以看到:

 

2.创建自己的代码仓库
点击Nexus“Log in”,输入默认用户名(admin)和默认密码(admin123)登录。可以点击上面的“设置”图标,在“设置”里可以添加用户、角色,对接LDAP等的设置,如下:

 

这里我们创建用户user:

 

创建完成后退出 admin,登录 user。
我们点击 Repository 下 Repositories 创建仓库:

 

然后这里填写相关信息,创建仓库 java:

 

我们来看一下创建的仓库:

 

到此我们自己的仓库创建成功。

3.Maven打包上传
1.上传
这里我们使用 IDEA 新建一个 Maven Project,命名为 utils,并在其中新建一个类,供我们后续测试使用。
配置 pom.xml:

<distributionManagement>
<repository>
<id>releases</id>
<url>http://192.168.2.20:8081/repository/java/</url>
</repository>
<snapshotRepository>
<id>Snapshots</id>
<url>http://192.168.2.20:8081/repository/java/</url>
</snapshotRepository>
</distributionManagement>
<build>
<plugins>
<!-- 打jar包插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>3.0.2</version>
<configuration>
<excludes>
<exclude>**/*.properties</exclude>
</excludes>
</configuration>
</plugin>
<!-- 打包源码插件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>3.0.1</version>
<configuration>
<attach>true</attach>
</configuration>
<executions>
<execution>
<phase>compile</phase>
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>

路径地址如下copy:

 

配置 settings.xml:

<servers>
<server>
<id>releases</id>
<username>user</username>
<password>123456</password>
</server>
<server>
<id>Snapshots</id>
<username>user</username>
<password>123456</password>
</server>
</servers>

然后使用 Maven 命令打包上传 Nexus:

mvn clean source:jar package
mvn deploy -e

到此上传成功。

 

2.引用
在 pom.xml 中添加如下配置即可:

<!-- nexus私服配置 -->
<repositories>
<repository>
<id>nexus</id>
<name>Nexus Repository</name>
<url>http://192.168.2.20:8081/repository/java/</url>
<releases>
<enabled>true</enabled>
</releases>
<!--snapshots默认是关闭的,需要开启 -->
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>com.example</groupId>
<artifactId>utils</artifactId>
<version>1.0</version>
</dependency>
</dependencies>

4.Gradle打包上传
1.上传
这里我们使用 Android Studio 新建一个 Gradle Project,然后创建一个 module 命名为 utils,并在其中新建一个类,供我们后续测试使用。
配置 Project 的 build.gradle:

allprojects {
repositories {
jcenter()
mavenLocal()
}
}
配置准备上传的 utils 的build.gradle文件:

apply plugin: "maven-publish"

//打包源码
task sourceJar(type: Jar) {
from sourceSets.main.allJava
}


publishing {
publications {
maven(MavenPublication) {
//指定group/artifact/version信息,可以不填。默认使用项目group/name/version作为groupId/artifactId/version
groupId project.group
artifactId project.name
version version
//如果是war包填写components.web,如果是jar包填写components.java
from components.java
//配置上传源码
artifact sourceJar {
classifier "sources"
}
}
}
repositories {
maven {
//指定要上传的maven私服仓库
url = "私服路径"
//认证用户和密码
credentials {
username 'www'
password 'www'
}
}

}
}


路径地址如下copy:

 

双击 uploadArchives(如下图中按钮)上传 utils:

 

等待module的上传,当全部显示ok时上传成功。

 

2.引用
配置 Project 的build.gradle文件:

allprojects {
repositories {
jcenter()
maven { url "http://192.168.2.20:8081/repository/java/" }
}
}
然后在 module 的 build.gradle 中添加依赖即可:

compile 'com.example:utils:1.0'

原文:https://blog.csdn.net/smartbetter/article/details/55116889

posted @ 2018-10-18 14:38  渔阳nice  阅读(407)  评论(0编辑  收藏  举报