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 用户安装不用创建)  

1.    #groupadd  apaduser    // 创建用户组   

2.    #useradd -g  apaduser apaduser    // 创建用户并指定用户组   

3.    #passwd  apaduser    // 为用户分配密码   

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

1.   #cd /opt  

2.   #mkdir maven  

3.    #chown -R  apaduser : apaduser  /opt/maven  

4.    #chmod  755  /opt/maven  

5.    #su -l  apaduser   

6.   #tar -zvxf apache-maven- 3.0 -bin.tar.gz

7.   #ln –s apache-maven-3.0 apache-maven   

3 、配置环境变量 (因为每种linux系统配置文件不一样,

详细请看http://blog.csdn.net/cuker919/archive/2010/11/17/6014727.aspx

1.   # cd /home/apaduser (“sudo su –“ for root user)

2.   # vi .bash_profile

3.   #. .bash_profile

在文件中添加如下行:  

1.   M2_HOME=/opt/maven/apache-maven  

2.   export M2_HOME

3.   PATH=$PATH:$M2_HOME/bin  

4.   export PATH  

4 、查看版本  

1.   #cd /opt/maven/apache-maven/bin  

2.   #mvn –version  

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

5、查看 .m2 目录  

1.   #cd /home/ apaduser /.m2  

2.   如果没有 .m2 目录,则可以手动添加一个   

3.   #mkdir .m2  

6 、如果需要把 maven repository 目录指定到其他目录,则修改 maven 安装目录下 conf 中的配置文件 settings.xml 文件  

1.   #vi /opt/maven/apache-maven/conf/settings.xml  

2.   将文件中 <localRepository>….</localRepository> 的注释打开   

3.   或者在文件中增加   在这个注释下增加   

4.   <localRepository>your repository path</localRepository>  

二、搭建 nexus 私服  
1
、解压 nexus-oss-webapp-1.8.0-bundle.tar.gz 文件到指定目录  

1.   # cp  nexus-oss-webapp- 1.8 . 0 -bundle.tar.gz  /usr/local

2.   #tar -zvxf nexus-oss-webapp- 1.8 . 0 -bundle.tar.gz

3.   #ln –s nexus-oss-webapp-1.8.0 nexus   

2 、启动 nexus 

1.   #cd / usr/local/nexus /bin/jsw  

2.     

3.   选择自己机器的版本:   

4.     

5.   #cd linux-x86- 64 /  

6.   #./nexus start  

7.     

8.   重启:   

9.   #./nexus restart  

10.    停止:   

11.    #./nexus stop  

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

4、配置  
1)
  点击左侧菜单 Repositories 
分别将右侧列表中  

1.   Apache Snapshots  

2.   Codehaus Snapshots  

3.   Maven Central  

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

2)增加新的 Repository ,有一些比较常用 jar 包在 nexus 提供的 repository 中可能找不到,  
一般比较常用的有  

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/   

添加步骤:  

点击 Add->Proxy Repository-> 填写 Repository ID, Repository Name,  以及 Remote Storage Location  其他的默认即可。   

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

4) 添加自己的 jar  

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 包,保存即可  

比如我们项目 需要如下几个包 :

javax.jms:jms:1.1:jar

proxool:proxool:0.9.1:jar

proxool:proxool-cglib:0.9.1:jar

com.lowagie:itextasian:1.0:jar

com.danga.MemCached:memcached:2.0.1:jar


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

6) 编写自己的 settings.xml ,文件内容如下:  

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> changethis localhost: 8081 /nexus</host>  

10.         <port> 80 </port>  

11.         <nonProxyHosts> changethis 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: // changethis 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: // changethis localhost:8081/nexus/content/groups/public</url>   

28.       </mirror>  

29.     </mirrors>  

30.       

31.     <profiles>  

32.       <profile>  

33.         <id> nexus </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> nexus </activeProfile>  

74.     </activeProfiles>  

75.   </settings>

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

7) 测试  
创建一个 maven 项目  

#mvn archetype:generate  

如果创建一个 web 项目可以选择 83 
填写相应的信息, maven 会从私服上下载相应的 jar 包,看到的地址应该都是 changethislocalhost  
项目创建成功后,将自己的 pom.xml 文件放在项目,执行  

  #mvn install  或者 #mvn  package    

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

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

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

你可能感兴趣的:(maven3)