背景
眾所周知,我們平時(shí)將JavaEE項(xiàng)目開發(fā)完后,需要將項(xiàng)目部署到服務(wù)器的tomcat上。常用的部署方式是將項(xiàng)目打包成war包放到tomcat的webapps下,然后重啟tomcat,然后通過ip地址+端口號(hào)訪問。這樣部署本身是沒問題的,但問題在于,如果還是在生產(chǎn)環(huán)境下的話,需要頻繁的更改優(yōu)化項(xiàng)目,那么就需要頻繁的將項(xiàng)目打war包,替換webapps下的war包,操作繁瑣。
接下來我們講述如何實(shí)現(xiàn)本地編程,然后部署項(xiàng)目到遠(yuǎn)程服務(wù)器的tomcat上,實(shí)現(xiàn)熱部署。
所用技術(shù)&工具
- maven(項(xiàng)目構(gòu)建和依賴管理)
- tomcat7插件 (部署到tomcat的插件)
- tomcat服務(wù)器 (web服務(wù)器)
- 編譯器推薦使用IDEA
1.確保本地具有遠(yuǎn)程tomcat的使用權(quán)限
修改Tomcat下{TOMCAT_HOME}conf/tomcat-users.xml配置文件,添加用戶名、密碼、權(quán)限。
<role rolename="manager-gui" />
<role rolename="manager-script" />
<role rolename="admin-gui" />
<role rolename="admin-script" />
<user username="tomcat" password="tomcat" roles="manager-gui,manager-script,admin-gui,admin-script"/>
2.配置Tomcat允許遠(yuǎn)程訪問
在遠(yuǎn)程服務(wù)器的{TOMCAT_HOME}conf/Catalina/localhost/
目錄下創(chuàng)建一個(gè)manager.xml文件,配置如下內(nèi)容:
<?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>
注:如果只想部分用戶使用,可在allow配置IP,例如
3.重啟遠(yuǎn)程Tomcat
在tomcat的bin目錄下依次執(zhí)行
//關(guān)閉tomcat
./shutdown.sh
//啟動(dòng)tomcat
./startup.sh
4.測試是否具有使用權(quán)限
訪問tomcat,例如http://192.168.0.102:8080(使用自己的服務(wù)器或是虛擬機(jī)的ip地址)
點(diǎn)擊Manager APP
![](/d/20211016/4930eb0451a9190c05ff185b6f0240a2.gif)
輸入剛才配置的tomcat的賬號(hào)和密碼
![](/d/20211016/18306f059aa5a91a42221db4ba884597.gif)
如果跳轉(zhuǎn)到這個(gè)頁面證明配置完成
![](/d/20211016/6e37012d4c05a349bc3c0629b4d3e442.gif)
當(dāng)然也可以在當(dāng)前頁面實(shí)現(xiàn)war的部署和替換,這也是另一種部署方式,不過依然沒有熱部署方便
問題:如果出現(xiàn)403報(bào)錯(cuò)如下
403 Access Denied
You are not authorized to view this page.
By default the Manager is only accessible from a browser running on the same machine as Tomcat. If you wish to modify this restriction, you'll need to edit the Manager's context.xml file.
If you have already configured the Manager application to allow access and you have used your browsers back button, used a saved book-mark or similar then you may have triggered the cross-site request forgery (CSRF) protection that has been enabled for the HTML interface of the Manager application. You will need to reset this protection by returning to the main Manager page. Once you return to this page, you will be able to continue using the Manager application's HTML interface normally. If you continue to see this access denied message, check that you have the necessary permissions to access this application.
If you have not changed any configuration files, please examine the file conf/tomcat-users.xml in your installation. That file must contain the credentials to let you use this webapp.
解決
修改 /webapps/manager/META_INF/context.xml文件,將文件中對(duì)訪問的來源受限設(shè)置注釋
<Context antiResourceLocking="false" privileged="true" >
<!--注釋這里,去除對(duì)訪問權(quán)限的設(shè)置
<Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />
-->
</Context>
然后直接刷新頁面就行了,無需重啟tomcat
5.在maven中配置遠(yuǎn)程Tomcat的管理員賬號(hào)
在本地maven的{MAVEN_HOME}/conf/settings.xml文件中節(jié)點(diǎn)下添加如下內(nèi)容:
<!-- 配置可以操作tomcat的用戶名和密碼 -->
<server>
<id>crocutax</id>
<!-- server login name -->
<username>tomcat</username>
<!-- server login password -->
<password>tomcat</password>
</server>
6.在項(xiàng)目中配置maven的tomcat7插件
<!-- 配置Tomcat插件 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<!-- 此處的名字必須和{MAVEN_HOME}/conf/settings.xml中配置的server節(jié)點(diǎn)的id一致-->
<server>crocutax</server>
<!--服務(wù)器端口號(hào)-->
<port>8080</port>
<!-- 項(xiàng)目發(fā)布的路徑,默認(rèn)就是tomcat/webapps目錄,可以指定深層次目錄,
留"/",則默認(rèn)在webapps目錄下部署ROOT.war包-->
<path></path>
<!-- 注意tomcat7此處的url,不能隨意修改,后綴必須是text,不能是html.
如果是本地tomcat部署,用localhost和ip都可以 -->
<url>http://localhost:8080/manager/text</url>
<!--<url>http://117.62.110.110:8080/manager/text</url>-->
<!--解決中文參數(shù)亂碼問題-->
<uriEncoding>UTF-8</uriEncoding>
<update>true</update>
<!--配置在tomcat\conf\tomcat-users.xml中定義的用戶名-->
<username>tomcat</username>
<password>tomcat</password>
</configuration>
</plugin>
- server : 名字必須和{MAVEN_HOME}/conf/settings.xml中配置的server節(jié)點(diǎn)的id一致
- port : 服務(wù)器端口號(hào)
- path :項(xiàng)目發(fā)布的路徑,默認(rèn)就是tomcat/webapps目錄,可以指定深層次目錄,留"/",則默認(rèn)在webapps目錄下部署ROOT.war包
- url : 注意tomcat7此處的url,不能隨意修改,后綴必須是text,不能是html. 如果是本地tomcat部署,用localhost和ip都可以uriEncoding :解決中文參數(shù)亂碼問題
- update : 熱部署,否則后期會(huì)報(bào)錯(cuò)
- username :配置{TOMCAT_HOME}\conf\tomcat-users.xml中定義的用戶名
- password :配置{TOMCAT_HOME}\conf\tomcat-users.xml中定義的密碼
7.在項(xiàng)目中啟動(dòng)maven的tomcat部署命令
初次部署可以使用 “tomcat7:deploy” 命令(在tomcat的webapps下沒有Root文件夾時(shí)使用)
如果已經(jīng)部署過使用 **“tomcat7:redeploy” **命令
若有時(shí)遇到項(xiàng)目沖突可以使用命令
-DskipTests的意思跳過測試
clean tomcat7:redeploy -DskipTests
使用的時(shí)候出現(xiàn)找不到文件的錯(cuò)誤,重新編譯或者打包一下即可
使用IDEA如下圖操作即可
![](/d/20211016/2ebe166d033c6537924f9dd28291a18a.gif)
當(dāng)然也可以配置快捷啟動(dòng)
![](/d/20211016/bee36ab2d5317e15f0f62207f4aba650.gif)
也可使用IDE->Terminal 或 項(xiàng)目根目錄打開dos窗口,輸入maven命令
至此tomcat+maven的熱部署就配置完成了,再也不用為了繁瑣的打包部署而揪心了
總結(jié)
以上所述是小編給大家介紹的SSM項(xiàng)目頻繁打成war包部署,使用tomcat和maven實(shí)現(xiàn)熱部署配置,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!