配置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 
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号