Eclipse+Maven远程部署项目到Tomcat中

Eclipse+Maven远程部署项目到Tomcat中有时候每次修改项目修改个小东西,都得登录服务器修改,这样未免比较麻烦,是不是可以修改完直接发布到服务器呢,答案是可以的。

欢迎大家来到IT世界,在知识的湖畔探索吧!

有时候每次修改项目修改个小东西,都得登录服务器修改,这样未免比较麻烦,是不是可以修改完直接发布到服务器呢,答案是可以的。

1.配置tomcat

先是修改tomcat-users.xml文件,该文件在安装目录的conf文件夹下面,我的是在/usr/local/apache-tomcat-8.5.11/conf,在<tomcat-users></tomcat-users>节点中增加:

<role rolename=”manager-gui” />

<role rolename=”manager-script” />

<user username=”tomcat” password=”tomcat” roles=”manager-gui, manager-script” />

将上面的password改为自己的密码,注意对于tomcat9来说,不能同时赋予用户manager-script和manager-gui角色。

保存tomcat-users.xml。

在tomcat服务器的conf/Catalina/localhost/目录下创建一个manager.xml文件,写入如下值:

<?xml version=”1.0″ encoding=”UTF-8″?>

<Context privileged=”true” antiResourceLocking=”false”

docBase=”${catalina.home}/webapps/manager”>

<Valve className=”org.apache.catalina.valves.RemoteAddrValve” allow=”^.*$” />

</Context>

以上这段照抄即可,默认情况下,Tomcat的Manager和Host-Manager只接受本机的请求,而要让它接受远程的请求,需要添加上面提到的manager.xml的配置。

保存退出。然后在bin目录下面执行startup.sh启动tomcat。

然后在浏览器中输入http://serverip:port/manager/html,此时会弹出要求输入用户名和密码对话框,输入manager-gui对应的用户和密码登录管理控制台(其中serverip为服务器ip,如果服务器在本地就是localhost或者127.0.0.1,端口为tomcat端口,默认8080)。以此确认manager是否配置正确。

2.在maven项目中配置

在pom.xml文件中,在plugins节点下添加如下plugin节点:

<plugin>

<groupId>org.apache.tomcat.maven</groupId>

<artifactId>tomcat7-maven-plugin</artifactId>

<version>2.2</version>

<configuration>

<url>http://192.168.199.201:8080/manager/text</url>

<username>tomcat</username>

<password>tomcat</password>

<update>true</update>

<path>/test_mvn</path>

</configuration>

</plugin>

将上面的serverip和port换成自己tomcat服务器的ip和端口。密码换成上面配置的manager-script角色的密码。path改为项目在tomcat服务器中的部署路径。

然后进行部署,如果是第一次部署,运行tomcat7:deploy进行自动部署(对于tomcat8,9,也是使用tomcat7命令),如果是更新了代码后重新部署更新,运行tomcat7:redeploy,如果第一次部署使用tomcat7:redeploy,则只会执行上传war文件,服务器不会自动解压部署。如果路径在tomcat服务器中已存在并且使用tomcat7:deploy命令的话,上面的配置中一定要配置<update>true</update>,不然会报错。

用这种方法注意多次启动tomcat后的内存泄漏问题

解决方法:

maven内添加

<dependency>

<groupId>se.jiderhamn.classloader-leak-prevention</groupId>

<artifactId>classloader-leak-prevention-servlet</artifactId>

<version>2.1.0</version>

</dependency>

web.xml内添加

<listener>

<listener-class>se.jiderhamn.classloader.leak.prevention.ClassLoaderLeakPreventorListener</listener-class>

</listener>

该拦截一定要在最顶部

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/31649.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信