我在平时工作中部署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:
1
2
3
4
5
6
7
8
9
|
< 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中增加如下配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
< 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节点:
1
2
3
4
5
6
7
|
< 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到项目根目录,运行下面的命令:
部署成功,如下:
然后我们就能在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日志文件中,如下:
1
2
3
|
信息:Undeployingcontext[/web-loab]
十月11,20143:52:26下午org.apache.catalina.startup.ExpandWardeleteDir
严重:[D:\tomcat\apache-tomcat-7.0.56\webapps\web-loab\WEB-INF]couldnotbecompletelydeleted.Thepresenceoftheremainingfilesmaycauseproblems
|
大概是因为Tomcat还在使用这个目录,无法删除,必须修改$TOMCAT_HOME/conf/context.xml:
1
|
< Context antiJARLocking = "true" antiResourceLocking = "true" >
|
3.2、Servelt.class offending
这个问题应该不属于本文主题范畴了,但可能因为这个导致Web项目启动起来却无法访问,报错信息如下:
1
2
|
十月11,20143:46:29下午org.apache.catalina.loader.WebappClassLoadervalidateJarFile
信息:validateJarFile(D:\tomcat\apache-tomcat-7.0.56\webapps\web-loab\WEB-INF\lib\servlet-api-6.0.29.jar)-jarnotloaded.SeeServletSpec3.0,section10.7.2.Offendingclass:javax/servlet/Servlet.class
|
原因是webapps目录下的某个Web项目的WEB-INF/lib目录下有servlet-api.jar,删除之,并在pom.xml中指定servelt-api.jar的scope为provided:
1
2
3
4
5
6
|
< 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插件部署项目的一些建议
这种方案能够实现持续快捷部署。但它有一些局限性:
因此初步建议只在开发环境使用这种部署方式,并且结合SVN、Git等版本控制软件做两个内部约定:
完!
分享到:
相关推荐
Maven +Tomcat+m2eclipse的热部署(hot deploy)
适用于Java后台开发Tomcat热部署使用者,包括Java环境的搭建、Tomcat的安装,以及Maven工程中热部署的配置
在用maven项目的时候,很多时候不想去再把项目部署到Tomcat上,然后发布并启动,这个时候我们就可以运用Tomcat热部署来配置,只需要再maven的配置文件加上一小段代码即可,非常方便! 启动的时候直接:右键项目--...
Eclipse Mars.2 Release (4.5.2),maven 3.3.9,tomcat7,JRebel6.4.3,包内包含JRebel与详细使用说明,纯手写,且亲测可用,eclipse,maven,tomcat可自行下载,JRebel为破解版,码字辛苦,望各位大神给1分辛苦费
使用maven 对java程序编译构建,打包和部署。自动化部署
主要介绍了IntelliJ IDEA使用maven实现tomcat的热部署,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
maven-tomcat-plugin让maven与tomcat配合得很好。它可以把应用部署到Tomcat服务器,也可以把tomcat作为内嵌服务器启动,就像jetty一样。 使用JPDA启动tomcat的远程调试功能。...而且具有tomcat的热部署功能。
主要介绍了Maven添加Tomcat插件实现热部署代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
NULL 博文链接:https://zheng12tian.iteye.com/blog/1772330
利用maven创建Web项目,并在eclipse测试部署web项目
主要介绍了maven tomcat plugin实现热部署,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
公司的项目一直手动maven打包、上传服务器、关闭/开启tomcat,整个流程下来耗时耗力,虽然可以将所有流程通过shell脚本一次性解决,但如果可以通过idea的Jenkins插件一键自动部署,那更省时省力。 下面是一个...
NULL 博文链接:https://xunclapton.iteye.com/blog/795561
eclipse+tomcat+Springmvc+maven 热部署 有需要的拿走
主要介绍了SSM项目频繁打成war包部署操作频繁?使用tomcat和maven实现热部署配置,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
maven项目的热项目,就是在tomcat启动的情况下, 服务器nginx 反向代理 负载均衡
maven常用知识整理:项目依赖 多模块 WAR依赖 打包 热部署 maven-tomcat-plugin maven-jetty-plugin
IDEA2020导入非maven项目并部署tomcat的方法在idea中将创建的java web项目部署到Tomcat中的过程图文详解idea打包成war包部署到tomcat及访问路径问题(图文详解)Idea配置maven-tomcat-plugin插件实现项目部署IDEA导入...
我们需要实现热部署,自然就需要通过maven操作tomcat,所以就需要maven取得操作tomcat的权限,现在这一步就是配置tomcat的可操作权限. 在tomcat的安装目录下,修改conf / tomcat-user.xml文件,在<tomcat> 节点下面增加...
到目前为止,还没有一个技术可以很完美的解决maven的实时调试,以上工具经本人修改过源码,算是一个比较完美的解决方案吧 望笑纳