nginx - JAVA 項目WAR包部署的適用場景?
問題描述
部署項目時一直用文件夾方式部署項目,近期嘗試使用WAR包項目部署,遇到了下面的問題:
上傳文件位置指定本地路徑,但由于獨立在項目外,還需要單獨配置項目才能訪問
公司項目數量多(1臺服務器200左右,20臺左右)時,每個項目這樣配置,運維工作十分繁重
維護時只調整了一個css或JS文件,卻要重新打包發布
對比之前文件夾方式,實在是很麻煩,想問下有經驗的同學:
你遇到的使用WAR包方式的應用場景是什么?
如何解決我遇到的問題?
問題解答
回答1:以下是我的實戰運維經驗:
配置應當是獨立于項目的,這樣可以只打一次war包,而運用到不同環境上;
運用自動化運維工具,如SaltStack、Ansible或Jenkins來幫助你批量操作;
如果預料到靜態資源會頻繁改動,最好跟Java項目分開來,部署到不同站點,或者用nginx做分流;
建議部署程序去解壓war文件(而不是讓Tomcat自己來解壓),停掉Tomcat,ROOT目錄用ln -s定向到新的目錄,再啟動Tomcat,這樣Tomcat會跑得更流暢;
舊有的目錄暫時不要刪,如果部署錯了,用ln -s把ROOT目錄切換到舊的,就能實現快速回滾。
回答2:實際經驗:我經手過的項目都是在weblogic上以目錄的形式發布,目錄結構:
DOMAINS --域└─domainA --域A └─apps--應用└─app1 --應用1 ├─deploy --部署 │ ├─src --Java源代碼(僅限項目實施開發的源代碼,不包含應用庫的源代碼),服務器統一編譯一次防止Java版本問題以及編碼問題 │ └─war --標準war包結構 ├─patch --增量更新目錄 ├─runtime --運行時目錄,日志,用戶文件之類的 └─tmp --臨時目錄
我按照這種標準結構寫了若干shell腳本來運維任務自動化,就是啟停,監控,更新什么的,其實也就花了幾天時間,代碼也不多,但是現在我再也沒有手動干過運維的事情了。
基本流程就是:代碼開發提交-->SVN導出增量更新包-->上傳至服務器-->服務器上執行
改一個html頁面都要重新打包,萬一打錯文件進去咋辦? 靜態的可以單獨發布,那我他媽就改一個JAVA也要重新打包就活該啦?
沒有一個容器是真正在war包里面發布和服務應用的,都是解壓到某個臨時位置,war包是壓縮格式,你讓任何一個容器每服務一個請求都去讀取壓縮文件里面的資源肯定會有性能問題的(至少JSP都是這樣)。
這是我的個人經手的一些小型項目的解決方案,大型項目,你可能需要全流程工具鏈,就是什么持續集成什么的。
相關文章:
1. javascript - 在 vue里面用import引入js文件,結果為undefined2. html - 爬蟲時出現“DNS lookup failed”,打開網頁卻沒問題,這是什么情況?3. 求教一個mysql建表分組索引問題4. 小程序怎么加外鏈,語句怎么寫!求救新手,開文檔沒發現5. html5 - input type=’file’ 上傳獲取的fileList對象怎么存儲于瀏覽器?6. 求救一下,用新版的phpstudy,數據庫過段時間會消失是什么情況?7. python沒入門,請教一個問題8. php如何獲取訪問者路由器的mac地址9. node.js - 用nodejs 的node-xlsx模塊去讀取excel中的數據,可是讀取出來的日期是數字,請問該如何讀取日期呢?10. javascript - 我的站點貌似被別人克隆了, google 搜索特定文章,除了域名不一樣,其他的都一樣,如何解決?
