Linux 安装配置maven3.0 以及搭建nexus私服

一、软件准备
1、apache-maven-3.0-bin.tar.gz 下载地址: http://www.apache.org/dyn/closer.cgi/maven/binaries/apache-maven-3.0-bin.tar.gz
2、nexus-oss-webapp-1.8.0-bundle.tar.gz 下载地址: http://nexus.sonatype.org/downloads/

二、maven安装配置
1、创建需要操作maven的用户组以及用户(如果用root用户安装不用创建)
Java代码   技术分享
  1. #groupadd configer  //创建用户组  
  2. #useradd -g configer configer  //创建用户并指定用户组  
  3. #passwd configer  //为用户分配密码  

2、创建解压目录,并将apache-maven-3.0-bin.tar.gz文件解压到指定目录

Java代码   技术分享
  1. #cd /opt  
  2. #mkdir maven  
  3. #chown -R configer:configer /opt/maven  
  4. #chmod 755 /opt/maven  
  5. #su -l configer  
  6. #tar -zvxf apache-maven-3.0-bin.tar.gz  


2、配置环境变量
Java代码   技术分享
  1. #vi /home/configer/.bash_profile  

在文件中添加如下行:
Java代码   技术分享
  1. M2_HOME=/opt/maven/apache-maven-3.0  
  2. export M2_HOME  
  3. PATH=$PATH:$M2_HOME/bin  
  4. export PATH  


3、查看版本
Java代码   技术分享
  1. #cd /opt/maven/apache-maven-3.0/bin  
  2. #mvn --version  

如果显示版本信息,应该会在${user}目录下创建.m2目录

4、查看.m2目录
Java代码   技术分享
  1. #cd /home/configer/.m2  
  2. 如果没有.m2目录,则可以手动添加一个  
  3. #mkdir .m2  


5、如果需要把maven的repository目录指定到其他目录,则修改maven安装目录下conf中的配置文件settings.xml文件
Java代码   技术分享
  1. #vi /opt/maven/apache-maven-3.0/conf/settings.xml  
  2. 将文件中<localRepository>....</localRepository>的注释打开  
  3. 或者在文件中增加 在这个注释下增加  
  4. <localRepository>your repository path</localRepository>  



二、搭建nexus私服
1、解压nexus-oss-webapp-1.8.0-bundle.tar.gz文件到指定目录
Java代码   技术分享
  1. #tar -zvxf nexus-oss-webapp-1.8.0-bundle.tar.gz  


2、启动nexus
Java代码   技术分享
  1. #cd /opt/maven/nexus-oss-webapp-1.8.0/bin/jsw  
  2.   
  3. 选择自己机器的版本:  
  4.   
  5. #cd linux-x86-32/  
  6. #./nexus start  
  7.   
  8. 重启:  
  9. #./nexus restart  
  10. 停止:  
  11. #./nexus stop  


3、运行nexus
在浏览器中输入:http://localhost:8081/nexus
就可以看到nexus 的主页,点击右上角Log in
默认用户名和密码是:admin/admin123
运行后会自动生成一个nexus工作目录sonatype-work,nexus下载的jar包会存放在
sonatype-work/nexus/storage中

4、配置
1)点击左侧菜单Repositories
分别将右侧列表中
Java代码   技术分享
  1. Apache Snapshots  
  2. Codehaus Snapshots  
  3. Maven Central  

三个repository 的Download Remote Index 配置改为True,并保存设置,
然后在列表中分别右键点击三个Repository,点击ReIndex

2)增加新的Repository,有一些比较常用jar包在nexus提供的repository中可能找不到,
一般比较常用的有
Java代码   技术分享
  1. JBOSS的两个:  
  2. http://repository.jboss.org/maven2/  
  3. http://repository.jboss.org/nexus/content/repositories/releases/  
  4. SUN的:  
  5. http://download.java.net/maven/2/  
  6. K-INT的:  
  7. http://developer.k-int.com/maven2/  
  8.   
  9. 因为找juel:juel-impl:2.2.1 这个jar包,所以我还添加了一个自己找的:  
  10. http://repository.exoplatform.org/content/groups/public/  


添加步骤:
Java代码   技术分享
  1. 点击Add->Proxy Repository->填写Repository ID, Repository Name, 以及Remote Storage Location 其他的默认即可。  


3) 将新增的Repository添加到Public Repositories中
在Public Repositories 的Configuration中,将多选Select中的项全部添加到左边,然后保存。

4) 添加自己的jar包
Java代码   技术分享
  1. 在repository列表中有一个3rd party,也就是第三方jar包,点击会看到一个Artifact Upload选项卡,点击后,填写相应的信息。  
  2. GAV Definition 一般选择 GAV Parameters  
  3. 然后添加Group:Artifact:Version:Package  
  4. 示例    juel:juel-impl:2.2.1:jar  


然后选择要上传的jar包,保存即可

5) nexus中设置代理服务器
选择左侧administrator菜单中的Server选项,在右侧打开的页面的中下部,有一个选择项:Default HTTP Proxy Settings(optional) 将复选框选中,填写相应的代理服务器信息即可。

6) 编写自己的settings.xml,文件内容如下:
Java代码   技术分享
  1. <settings>  
  2.   <proxies>  
  3.     <proxy>  
  4.       <id>normal</id>  
  5.       <active>true</active>  
  6.       <protocol>http</protocol>  
  7.       <username>deployment</username>  
  8.       <password>deploy</password>  
  9.       <host>localhost:8081/nexus</host>  
  10.       <port>80</port>  
  11.       <nonProxyHosts>localhost:8081/nexus</nonProxyHosts>  
  12.     </proxy>  
  13.   </proxies>  
  14.   
  15.   <mirrors>  
  16.     <mirror>  
  17.       <!--This is used to direct the public snapshots repo in the   
  18.           profile below over to a different nexus group -->  
  19.       <id>nexus-public-snapshots</id>  
  20.       <mirrorOf>public-snapshots</mirrorOf>  
  21.       <url>http://localhost:8081/nexus/content/groups/public-snapshots</url>  
  22.     </mirror>  
  23.     <mirror>  
  24.       <!--This sends everything else to /public -->  
  25.       <id>nexus</id>  
  26.       <mirrorOf>*</mirrorOf>  
  27.       <url>http://localhost:8081/nexus/content/groups/public</url>  
  28.     </mirror>  
  29.   </mirrors>  
  30.     
  31.   <profiles>  
  32.     <profile>  
  33.       <id>development</id>  
  34.       <repositories>  
  35.         <repository>  
  36.           <id>central</id>  
  37.           <url>http://central</url>  
  38.           <releases><enabled>true</enabled></releases>  
  39.           <snapshots><enabled>true</enabled></snapshots>  
  40.         </repository>  
  41.       </repositories>  
  42.      <pluginRepositories>  
  43.         <pluginRepository>  
  44.           <id>central</id>  
  45.           <url>http://central</url>  
  46.           <releases><enabled>true</enabled></releases>  
  47.           <snapshots><enabled>true</enabled></snapshots>  
  48.         </pluginRepository>  
  49.       </pluginRepositories>  
  50.     </profile>  
  51.     <profile>  
  52.       <!--this profile will allow snapshots to be searched when activated-->  
  53.       <id>public-snapshots</id>  
  54.       <repositories>  
  55.         <repository>  
  56.           <id>public-snapshots</id>  
  57.           <url>http://public-snapshots</url>  
  58.           <releases><enabled>false</enabled></releases>  
  59.           <snapshots><enabled>true</enabled></snapshots>  
  60.         </repository>  
  61.       </repositories>  
  62.      <pluginRepositories>  
  63.         <pluginRepository>  
  64.           <id>public-snapshots</id>  
  65.           <url>http://public-snapshots</url>  
  66.           <releases><enabled>false</enabled></releases>  
  67.           <snapshots><enabled>true</enabled></snapshots>  
  68.         </pluginRepository>  
  69.       </pluginRepositories>  
  70.     </profile>  
  71.   </profiles>  
  72.   <activeProfiles>  
  73.     <activeProfile>development</activeProfile>  
  74.   </activeProfiles>  
  75. </settings>  

将settings.xml文件复制到${user}/.m2目录下

7) 测试
创建一个maven项目
Java代码   技术分享
  1. #mvn archetype:generate  

如果创建一个web项目可以选择83
填写相应的信息,maven会从私服上下载相应的jar包,看到的地址应该都是localhost的
项目创建成功后,将自己的pom.xml文件放在项目,执行
Java代码   技术分享
  1. #mvn install 或者#mvn package   

mvn会下载pom.xml文件定义的jar依赖

下载完成后,你可以在自己指定的repository目录下,如果没有指定则是在.m2/repository目录下查看自己的jar包

至此,我们的maven安装以及私服的搭建工作就完成了。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。