精品免费在线观看-精品欧美-精品欧美成人bd高清在线观看-精品欧美高清不卡在线-精品欧美日韩一区二区

17站長網(wǎng)

17站長網(wǎng) 首頁 網(wǎng)站 服務(wù)器 查看內(nèi)容

maven自動部署到遠(yuǎn)程tomcat服務(wù)器的方法

2022-10-22 22:34| 查看: 2496 |來源: 互聯(lián)網(wǎng)

使用maven的自動部署功能可以很方便的將maven工程自動部署到遠(yuǎn)程tomcat服務(wù)器,節(jié)省了大量時間。 本文章適用于tomcat的7.x ,8.x, 9.x版本。 下面是自動部的步驟 1,首先,配置tomcat的manager 編輯遠(yuǎn)程tomcat服

使用maven的自動部署功能可以很方便的將maven工程自動部署到遠(yuǎn)程tomcat服務(wù)器,節(jié)省了大量時間。

本文章適用于tomcat的7.x ,8.x, 9.x版本。

下面是自動部的步驟

1,首先,配置tomcat的manager
編輯遠(yuǎn)程tomcat服務(wù)器下的conf/tomcat-users.xml,在末尾增加(其實只要拉到文件末尾,去掉注釋改一下就可以了)

將上面的password改為自己的密碼,注意對于tomcat9來說,不能同時賦予用戶manager-script和manager-gui角色。

保存tomcat-users.xml。

在tomcat服務(wù)器的conf/Catalina/localhost/目錄下創(chuàng)建一個manager.xml文件,寫入如下值:

保存退出。

然后在瀏覽器中輸入http://serverip:port/manager/html,此時會彈出要求輸入用戶名和密碼對話框,輸入manager-gui對應(yīng)的用戶和密碼登錄管理控制臺(其中serverip為服務(wù)器ip,如果服務(wù)器在本地就是localhost或者127.0.0.1,端口為tomcat端口,默認(rèn)8080)。以此確認(rèn)manager是否配置正確。正確結(jié)果示例如下:

2,在maven項目中添加配置
在pom.xml文件中,在plugins節(jié)點(diǎn)下添加如下plugin節(jié)點(diǎn)

org.apache.tomcat.maven tomcat7-maven-plugin 2.2 http://serverip:port/manager/text admin password true /webapp

將上面的serverip和port換成自己tomcat服務(wù)器的ip和端口。密碼換成上面配置的manager-script角色的密碼。path改為項目在tomcat服務(wù)器中的部署路徑。

然后進(jìn)行部署,如果是第一次部署,運(yùn)行mvn tomcat7:deploy進(jìn)行自動部署(對于tomcat8,9,也是使用tomcat7命令),如果是更新了代碼后重新部署更新,運(yùn)行mvn tomcat7:redeploy,如果第一次部署使用mvn tomcat7:redeploy,則只會執(zhí)行上傳war文件,服務(wù)器不會自動解壓部署。如果路徑在tomcat服務(wù)器中已存在并且使用mvn tomcat7:deploy命令的話,上面的配置中一定要配置true,不然會報錯。

如果IDE是eclipse,就在runas->run configurations中配置一個maven build,intellij類似。

3. 內(nèi)存泄漏

使用上面的方法進(jìn)行部署后會出現(xiàn)嚴(yán)重的內(nèi)存泄漏現(xiàn)象。tomcat的manager提供了診斷在部署時是否產(chǎn)生內(nèi)存泄漏的功能,在上面提到的http://serverip:port/manager/html這個頁面底部有一個“Find leaks”的按鈕,如下:

點(diǎn)擊按鈕,網(wǎng)頁頭部出現(xiàn)如下信息說明在部署的時候有內(nèi)存泄漏:

上面的消息顯示部署的test項目存在內(nèi)存泄漏,如果同一項目多次重新部署,則一個項目名可能會出現(xiàn)多次。

部署時產(chǎn)生內(nèi)存泄漏的原因是每次(重新)部署時,Tomcat會為項目新建一個類加載器,而舊的類加載器沒有被GC回收。maven的庫classloader-leak-prevention-servlet可以用來解決這個問題。具體方案為:

(1)添加maven依賴:

se.jiderhamn.classloader-leak-prevention classloader-leak-prevention-servlet 2.1.0

(2)在項目的web.xml中添加一個Listener(必須讓此Listener成為web.xml中的第一個Listener,否則不起作用)

se.jiderhamn.classloader.leak.prevention.ClassLoaderLeakPreventorListener

這樣部署時的內(nèi)存泄漏就解決了。

注意:

1) 添加這個Listener后,默認(rèn)在tomcat關(guān)閉5s后jvm會進(jìn)行內(nèi)存回收的操作,具體時間設(shè)置可在下面的第三個參考鏈接中找到,所以,在關(guān)閉后的5s內(nèi),再次啟動tomcat,可能會存在問題,導(dǎo)致啟動無效(如果出現(xiàn)tomcat重啟后日志顯示正常但是服務(wù)器不工作的話考慮一下是不是這個問題)。

2)這個Listener只解決部署的內(nèi)存泄漏,其他問題(如jdbc等)產(chǎn)生的內(nèi)存泄漏還需要自己解決。

參考:

http://stackoverflow.com/questions/7788280/memory-leak-when-redeploying-application-in-tomcat#answer-36295683

http://java.jiderhamn.se/2011/12/11/classloader-leaks-i-how-to-find-classloader-leaks-with-eclipse-memory-analyser-mat/

https://github.com/mjiderhamn/classloader-leak-prevention

4,錯誤排除。

(1) 執(zhí)行tomcat7:deploy顯示Build Success成功但是沒有效果,也沒有在本地生成war包,檢查一下maven配置文件中packaging標(biāo)簽是否設(shè)置為war。即:

war

如果不是(比如說是pom),那么改成war應(yīng)該就可以了。

(2) 如果出現(xiàn)在本地tomcat服務(wù)器自動部署沒有任何問題,部署到遠(yuǎn)程服務(wù)器出現(xiàn)下面的Cannot invoke Tomcat manager: Connection reset by peer: socket write error 錯誤:

[ERROR] Failed to execute goal org.apache.tomcat.maven:tomcat7-maven-plugin:2.2:deploy (default-cli) on project webapp: Cannot invoke Tomcat manager: Connection reset by peer: socket write error -> [Help 1] org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal org.apache.tomcat.maven:tomcat7-maven-plugin:2.2:deploy (default-cli) on project clyf_wechat: Cannot invoke Tomcat manager at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:212) at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153) at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145) at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:116) at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:80) at org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build(SingleThreadedBuilder.java:51) at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:128) at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:307) at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:193) at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:106) at org.apache.maven.cli.MavenCli.execute(MavenCli.java:863) at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:288) at org.apache.maven.cli.MavenCli.main(MavenCli.java:199) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:497) at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Launcher.java:289) at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:229) at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(Launcher.java:415) at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:356) Caused by: org.apache.maven.plugin.MojoExecutionException: Cannot invoke Tomcat manager at org.apache.tomcat.maven.plugin.tomcat7.AbstractCatalinaMojo.execute(AbstractCatalinaMojo.java:141) at org.apache.tomcat.maven.plugin.tomcat7.AbstractWarCatalinaMojo.execute(AbstractWarCatalinaMojo.java:68) at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(DefaultBuildPluginManager.java:134) at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:207) ... 20 more Caused by: java.net.SocketException: Connection reset by peer: socket write error at java.net.SocketOutputStream.socketWrite0(Native Method) at java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:109) at java.net.SocketOutputStream.write(SocketOutputStream.java:153) at org.apache.http.impl.io.AbstractSessionOutputBuffer.write(AbstractSessionOutputBuffer.java:181) at org.apache.http.impl.io.ContentLengthOutputStream.write(ContentLengthOutputStream.java:115) at org.apache.tomcat.maven.common.deployer.TomcatManager$RequestEntityImplementation.writeTo(TomcatManager.java:880) at org.apache.http.entity.HttpEntityWrapper.writeTo(HttpEntityWrapper.java:89) at org.apache.http.impl.client.EntityEnclosingRequestWrapper$EntityWrapper.writeTo(EntityEnclosingRequestWrapper.java:108) at org.apache.http.impl.entity.EntitySerializer.serialize(EntitySerializer.java:117) at org.apache.http.impl.AbstractHttpClientConnection.sendRequestEntity(AbstractHttpClientConnection.java:265) at org.apache.http.impl.conn.ManagedClientConnectionImpl.sendRequestEntity(ManagedClientConnectionImpl.java:203) at org.apache.http.protocol.HttpRequestExecutor.doSendRequest(HttpRequestExecutor.java:236) at org.apache.http.protocol.HttpRequestExecutor.execute(HttpRequestExecutor.java:121) at org.apache.http.impl.client.DefaultRequestDirector.tryExecute(DefaultRequestDirector.java:682) at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:486) at org.apache.http.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:863) at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82) at org.apache.tomcat.maven.common.deployer.TomcatManager.invoke(TomcatManager.java:742) at org.apache.tomcat.maven.common.deployer.TomcatManager.deployImpl(TomcatManager.java:705) at org.apache.tomcat.maven.common.deployer.TomcatManager.deploy(TomcatManager.java:388) at org.apache.tomcat.maven.plugin.tomcat7.deploy.AbstractDeployWarMojo.deployWar(AbstractDeployWarMojo.java:85) at org.apache.tomcat.maven.plugin.tomcat7.deploy.AbstractDeployMojo.invokeManager(AbstractDeployMojo.java:82) at org.apache.tomcat.maven.plugin.tomcat7.AbstractCatalinaMojo.execute(AbstractCatalinaMojo.java:132) ... 23 more

使用mvn tomcat7:redeploy時出現(xiàn)如下情況

經(jīng)過查詢Tomcat文檔后發(fā)現(xiàn),這是由于Tomcat的遠(yuǎn)程地址攔截器造成的結(jié)果,默認(rèn)情況下,Tomcat的Manager和Host-Manager只接受本機(jī)的請求,而要讓它接受遠(yuǎn)程的請求,需要添加上面提到的manager.xml的配置(第一步配置過了就不要加了),也就是:

由于Tomcat的Manager可以執(zhí)行項目的部署、卸載等敏感操作,如果你只想允許特定的IP地址訪問Manager,可在上面的allow屬性中設(shè)置規(guī)則。具體規(guī)則設(shè)置見下面的鏈接:

http://tomcat.apache.org/tomcat-7.0-doc/config/valve.html#Remote_Address_Filter

問題說明:http://tomcat.apache.org/tomcat-7.0-doc/manager-howto.html#Configuring_Manager_Application_Access

(3)自動部署顯示成功,war包也上傳成功,但是war不自動解壓自動部署。

如果你在tomcat的server.xml中通過設(shè)置標(biāo)簽來部署相同名稱的項目的話,maven發(fā)布到該服務(wù)器的war不會被自動解壓,部署,更新,需要去掉server.xml中該項目的標(biāo)簽。

5. 其他
如果想要實現(xiàn)對部署路徑加版本,可將上面tomcat7-maven-pluginconfiguration的path設(shè)置為

/webapp#version

的形式,部署后,當(dāng)前項目在服務(wù)器端的路徑就是/webapp/version。舉個例子,如果path設(shè)置為 test#1.0,那么服務(wù)端項目實際的路徑就是/test/1.0。如下:

如果名字和版本號之間是兩個#,效果就是制定當(dāng)前項目在manager網(wǎng)頁中顯示的版本,路徑不變,舉個例子,path設(shè)置為test##1.0,實際部署路徑為/test,但是在manager網(wǎng)頁中,顯示如下,注意Version一欄的值:

參考:

http://tomcat.apache.org/tomcat-7.0-doc/config/context.html#Naming

本文最后更新于 2022-10-22 22:34,某些文章具有時效性,若有錯誤或已失效,請在網(wǎng)站留言或聯(lián)系站長:17tui@17tui.com
·END·
站長網(wǎng)微信號:w17tui,關(guān)注站長、創(chuàng)業(yè)、關(guān)注互聯(lián)網(wǎng)人 - 互聯(lián)網(wǎng)創(chuàng)業(yè)者營銷服務(wù)中心

免責(zé)聲明:本站部分文章和圖片均來自用戶投稿和網(wǎng)絡(luò)收集,旨在傳播知識,文章和圖片版權(quán)歸原作者及原出處所有,僅供學(xué)習(xí)與參考,請勿用于商業(yè)用途,如果損害了您的權(quán)利,請聯(lián)系我們及時修正或刪除。謝謝!

17站長網(wǎng)微信二維碼

始終以前瞻性的眼光聚焦站長、創(chuàng)業(yè)、互聯(lián)網(wǎng)等領(lǐng)域,為您提供最新最全的互聯(lián)網(wǎng)資訊,幫助站長轉(zhuǎn)型升級,為互聯(lián)網(wǎng)創(chuàng)業(yè)者提供更加優(yōu)質(zhì)的創(chuàng)業(yè)信息和品牌營銷服務(wù),與站長一起進(jìn)步!讓互聯(lián)網(wǎng)創(chuàng)業(yè)者不再孤獨(dú)!

掃一掃,關(guān)注站長網(wǎng)微信

大家都在看

熱門排行

    最近更新

      返回頂部
      主站蜘蛛池模板: 欧美成人a大片 | www黄色大片| 欧美日韩国产片 | 国产精品视频分类 | 伊人色综合97 | 欧美一级特黄毛片免费 | 91视频青青 | 黄色成年视频 | 国产午夜精品视频 | 婷婷在线综合 | 国产经典一区 | 免费视频精品 | 这里只有精品首页 | 国产精品一区91 | 中文乱码一二三四有限公司 | 欧美一区二区三区在线播放 | 免费国产视频在线观看 | 免费一级黄色 | 国产爽妇网 | 狠狠色成人综合网图片区 | 欧美日韩性大片 | 欧美在线观看视频一区 | 毛片毛片毛片毛片毛片毛片 | aⅴ一区二区三区无卡无码 aⅴ在线免费观看 | 日韩大片免费观看 | 精品国产免费一区二区三区 | 久久国产精品女 | 日韩精品中文字幕一区二区三区 | 成人毛片免费观看视频 | 亚洲人成综合网站在线 | 免费中文字幕一级毛片 | 欧美婷婷综合 | 国产精品视频观看 | 国产精品短视频免费观看 | 亚洲成人77777| 国产精品一国产精品免费 | 成人网久久 | 欧美最新一区二区三区四区 | 午夜性刺激免费视频 | 久久亚洲精品中文字幕第一区 | 欧美黄色性生活视频 |