maven构建web应用

在进行web开发的时候,我们总是无法避免打开浏览器对应用进行测试,下面我们使用maven配置web应用。

1.采用jetty插件部署web项目

使用jetty-maven-plugin十分简单。只需要指定该插件的坐标,并且稍加配置即可,详细代码如下:

<plugin>
    <groupId>org.mortbay.jetty</groupId>
    <artifactId>jetty-maven-plugin</artifactId>
    <version>7.1.6.v20100715</version>
    <configuration>
     <scanIntervalSeconds>10</scanIntervalSeconds>
     <webAppConfig>
      <contextPath>/test</contextPath>
     </webAppConfig>
    </configuration>
   </plugin>

我们需要注意到是jetty-maven-plugin并不是官方的Maven插件,它的groupId是org.mortbay.jetty,上述代码中使用的了jetty7的最新版本,在该插件的配置中scanIntervalSeconds顾名思义表示该插件扫描项目变更的时间间隔,如果不进行配置那么扫描的间隔就为0,而webappConfig元素下跌contextPath表示该项目部署后的context path即可通过 http://hostname:port/test进行访问。

我们在启动jetty是需要进行稍微的改动,由于jetty-maven-plugin的插件groupId是org.mortbay.jetty,在默认情况下只有org.apache.maven.plugins  和 prg.codehaus.mojo两个groupId下单插件才支持简化的命定行调用,所以需要修改${MAVEN_HOME}/conf/settings.xml 具体如下:

  <pluginGroups>
    <!-- pluginGroup
     | Specifies a further group identifier to use for plugin lookup.
    <pluginGroup>com.your.plugins</pluginGroup>
    -->
    <pluginGroup>org.mortbay.jetty</pluginGroup>
 <pluginGroup>org.codehaus.cargo</pluginGroup> 
  </pluginGroups>

现在-可以运行如下命令即可

mvn jetty:run

jetty-maven-plugins  会启动Jetty,并且默认监听本地的8080端口,并将当前的项目部署到容器中,同时还会根据用户配置扫描代码改动。

如果希望使用其他端口,可以添加jetty.port参数例如:

mvn jetty:run -Djetty.port=9999

要停止jetty容器,只需要采用Ctrl+C即可。

2.使用Cargo实现自动化部署

Cargo是一组帮助用户操作web容器的工具 ,它能够帮助用户实现自动化部署,而且它几乎支持所有的web容器,如tomcat,jetty,jboss和Glassfish等,Cargo通过cargo-maven2-plugin提供了Maven的集成,mavne用户可以使用该插件将web项目部署到web容器中,虽然cargo-mavne2-plugin与jetty-maven-plugin的功能看起来很相似,但它们的目的不同,jetty-maven-plugin 主要用来帮助日常的快速开发,而cargo-mavne2-plugin主要服务于自动化部署。

Cargo支持两种本地部署到方式,分别为standalone模式和existing模式。在standlone模式中,Cargo会从Web容器中的安装目录复制一份配置到用户指定的目录,然后再此目录下进行部署应用,每次重新构建时候这个目录都会被清空。

配置Cargo中的standalonee模式如下:

<plugin>
        <groupId>org.codehaus.cargo</groupId>
         <artifactId>cargo-maven2-plugin</artifactId>
          <version>1.2.3</version>
          <configuration>
            <container>
                <containerId>tomcat6x</containerId>
                 <home>E:\资料库\资料库\java\开发工具\tomcat\tomcat6\apache-tomcat-6.0.35</home>
            </container>
           
            <configuration>
              <type>standalone</type>
               <home>${project.build.directory}/tomcat6x</home>
               <properties>
                   <cargo.servlet.port>8081</cargo.servlet.port>

              <cargo.jvmargs>
                 -Xdebug
                -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8787
             </cargo.jvmargs>
               </properties>
            </configuration>
          </configuration>

     <executions>
        <execution>
         <id>cargo-run</id>
         <phase>pre-integration-test</phase>
       <goals>
       <goal>run</goal>
       </goals>
     </execution>
    </executions>
      </plugin>

由于cargo-maven2-plugin 的groupId是org.codehaus.cargo,这不是官方的两个Maven插件,因此用户需要在setting中进行配置。

上述的cargo-maven2-plugin的具体配置包括了container和configuration的两个元素,configuration元素中的type表示部署到模式,home元素表示复制容器到什么位置,这里的值为${project.build.directory},表示的是构建输出目录,即target/下的tomcat6x目录。container元素下的containerId表示容器的类型,hoem表示容器的安装目录。

要让Cargo启动tomcat并部署应用,只需要运行

mvn cargo:start

默认情况下Cargo会让web容器监听8080端口,如果需要修改只需要配置

<properties>
                   <cargo.servlet.port>8081</cargo.servlet.port>
</properties>

现在就可以通过http://localhost:portal/project名称进行访问即可.

其中的设置远程调试

<cargo.jvmargs>
        -Xdebug
        -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8787
</cargo.jvmargs>

 绑定任务

<executions>
     <execution>
      <id>cargo-run</id>
      <phase>pakcage</phase>
      <goals>
       <goal>run</goal>
      </goals>
     </execution>
    </executions>

 <phase>package</phase> 将任务绑定到生命中的中的package阶段。

       

采用exitsting模式进行部署具体实现如下:

 <plugin>
        <groupId>org.codehaus.cargo</groupId>
         <artifactId>cargo-maven2-plugin</artifactId>
          <version>1.0</version>
          <configuration>
            <container>
                <containerId>tomcat6x</containerId>
                 <home>E:\资料库\资料库\java\开发工具\tomcat\tomcat6\apache-tomcat-6.0.35</home>
            </container>
            <configuration>
              <type>existing</type>
              <home>E:\资料库\资料库\java\开发工具\tomcat\tomcat6\apache-tomcat-6.0.35</home>
            </configuration>
          </configuration>
   </plugin>

基于上述配置运行mvn cargo:start之后,便能够在tomcat的webapps目录下看到被部署到Maven项目。

3.部署至远程web容器

除了让Cargo直接管理本地web容器然后部署应用之外,也可以让Cargo部署应用之远程的正在执行的web容器中,当然前提是有用容器的相应管理员权限。相关配置如下:
   <plugin>
    <groupId>org.codehaus.cargo</groupId>
    <artifactId>cargo-maven2-plugin</artifactId>
    <version>1.0</version>
    <configuration>
     <container>
      <containerId>tomcat6x</containerId>
      <type>remote</type>
     </container>
     <configuration>
      <type>runtime</type>
      <properties>
       <cargo.remote.username>admin</cargo.remote.username>
       <cargo.remote.password>password</cargo.remote.password>
       <cargo.remote.url>http://localhost:8080/manager</cargo.remote.url>
      </properties>
     </configuration>
    </configuration>
   </plugin>

我们可以使用 mvn cargo:redeploy进行部署,如果容器中已经部署了当前应用,Cargo会先将其卸载,然后在进行部署。

由于自动化部署本身就不是很简单的事情,在加上Cargo要兼容各种不同类型的web容器,以此cargo-maven2-plugin的相关配置显得很复杂,这个时候的文档显得尤为重要,如果想进一步了解cargo,可以访问http://cargo.codehaus.org/Maven2+plugin.

猜你喜欢

转载自liuwuhen.iteye.com/blog/1679454