開發過程使用Tomcat Maven插件持續快捷部署Web項目

jopen 10年前發布 | 84K 次閱讀 Tomcat 應用服務器

    我在平時工作中部署Web項目到測試服務器上的Tomcat時用的是Hudson。Hudson本身已經跟SVN、Git、Maven集成并且支持添加各種插件。但如果使用Hudson,我需要配置兩個任務:一個任務負責打包項目成WAR,另外一個任務負責部署打包好的WAR包到目標服務器的Tomcat上。雖然任務只需要配置一次,但每次修改代碼提交后,都得切換到瀏覽器點Hudson構建任務頁面上的Build Now按鈕,然后還得跳轉到另一個頁面觀察是否有報錯。煩不勝煩,偶然發現Tomcat Maven插件支持直接部署項目到Tomcat中,嘗試一番后終于搞定,總結于此。

    網上關于這個主題的文章也不少,過程也大同小異,但本文最主要的是想記錄下我在此過程中踩過的坑和關于這種部署方案的建議。

 

1、準備工作

    下載安裝并配置好Tomcat和Maven。

    準備好一個Maven Web項目。

 

?2、Maven部署Web項目到Tomcat的配置?

?2.1、配置Tomcat角色?

    Maven自動部署實際上調的是Tomcat安裝目錄下的manager功能。而為了能正常訪問http://localhost:8080/manager頁面,我們需要修改$TOMCAT_HOME/conf目錄下的tomcat-users.xml:

<tomcat-users>
  <role rolename="tomcat"/>
  <role rolename="manager"/>
  <role rolename="manager-gui"/>
  <role rolename="manager-script" />
  <role rolename="admin-gui"/>
  <user username="tomcat" password="tomcat" roles="tomcat,manager,
      manager-gui,manager-script,admin-gui" />
</tomcat-users>

2.2、修改pom.xml增加Tomcat Maven插件

   我使用的Tomcat7,pom.xml中增加如下配置:

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <spring.version>3.2.2.RELEASE</spring.version>
        <finalName>web-loab</finalName>
    </properties>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <configuration>
                    <url>http://localhost:8080/manager/text</url>
                    <server>tomcat</server>
                    <username>tomcat</username>
                    <password>tomcat</password>
                    <path>/${finalName}</path>
                </configuration>
            </plugin>
        </plugins>
    </build>

   上面username、password來自tomcat-users.xml。server是Tomcat服務器名稱。path是訪問應用的路徑。url指定Tomcat管理頁路徑。

2.3、修改Maven的settings.xml

   在$USER_HOME/.m2目錄下找到settings.xml,添加server節點:

<servers>
    <server>
       <id>tomcat</id>
       <username>tomcat</username>
       <password>tomcat</password>
    </server>
</servers>

    上面的username、password依然與tomcat-users.xml中相同,id與2.2中的server相同

2.4、部署項目到Tomcat

    先確保Tomcat服務器已經啟動,然后cd到項目根目錄,運行下面的命令:

mvn clean tomcat7:redeploy

    部署成功,如下:

開發過程使用Tomcat Maven插件持續快捷部署Web項目

    然后我們就能在Tomcat安裝目錄的webapps目錄下找到新部署的WAR包。

    初次部署用的是tomcat7:deploy命令,重新部署可以用tomcat7:redeploy命令(推薦統一用這個),Tomcat Maven插件支持的命令包括:run、shutdown、run-war-only、exec-war、standalone-war-only、deploy、standalone-war、undeploy、run-war、redeploy等。

 

?3、踩過的坑?

    光看上面的過程,似乎非常順暢,但世上的事總是不會那么順利的。下面列舉幾個我踩過的坑。

?3.1、Windows系統下,redeploy過程無法刪除舊項目的目錄?

    報錯信息在$TOMCAT_HOME/logs下的catalina日志文件中,如下:

信息: Undeploying context [/web-loab]
十月 11, 2014 3:52:26 下午 org.apache.catalina.startup.ExpandWar deleteDir
嚴重: [D:\tomcat\apache-tomcat-7.0.56\webapps\web-loab\WEB-INF] could not be completely deleted. The presence of the remaining files may cause problems

    大概是因為Tomcat還在使用這個目錄,無法刪除,必須修改$TOMCAT_HOME/conf/context.xml:

<Context antiJARLocking="true" antiResourceLocking="true">

?3.2、Servelt.class offending?

    這個問題應該不屬于本文主題范疇了,但可能因為這個導致Web項目啟動起來卻無法訪問,報錯信息如下:

十月 11, 2014 3:46:29 下午 org.apache.catalina.loader.WebappClassLoader validateJarFile
信息: validateJarFile(D:\tomcat\apache-tomcat-7.0.56\webapps\web-loab\WEB-INF\lib\servlet-api-6.0.29.jar) - jar not loaded. See Servlet Spec 3.0, section 10.7.2. Offending class: javax/servlet/Servlet.class

    原因是webapps目錄下的某個Web項目的WEB-INF/lib目錄下有servlet-api.jar,刪除之,并在pom.xml中指定servelt-api.jar的scope為provided:

<dependency>
    <groupId>org.apache.tomcat</groupId>
    <artifactId>servlet-api</artifactId>
    <version>6.0.29</version>
    <scope>provided</scope>
</dependency>

3.3、版本問題

    確保Web項目的Java Build Path使用的JDK版本、Java Compiler的編譯JDK版本以及Project Facets里的Java版本一致。

    如果用的Tomcat6,則pom.xml中配置tomcat6-maven-plugin,如果用的tomcat7則用tomcat7-maven-plugin。或者默認用tomcat-maven-plugin。


4、有關使用Tomcat Maven插件部署項目的一些建議

    這種方案能夠實現持續快捷部署。但它有一些局限性:

  • 要求從本地開發環境能直接訪問Tomcat服務器所在網段

  • 不能保留歷史部署包

    因此初步建議只在開發環境使用這種部署方式,并且結合SVN、Git等版本控制軟件做兩個內部約定:

  • 所有可部署版本代碼都必須先簽入一個名為deploy-xx的分支,xx表示當前可部署版本,然后切到deploy-xx分支再部署項目

  • 以后增加了新功能,則需新建另一個deploy分支,并增大版本號。這樣可以利用版本控制軟件幫我們保留歷史可部署代碼(解決了上面提到的第二個局限性)。尤其是多個項目集成時,最好保證每一次集成時各個項目的deploy分支帶的版本后綴相同。這樣可以方便各個項目代碼集體回滾 

完!

來自:http://my.oschina.net/feichexia/blog/326893

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!