sprinboot項(xiàng)目啟動(dòng)一半到圖形化界面卡住了的解決
sprinboot項(xiàng)目啟動(dòng)一半到圖形化界面卡住
問題
有一個(gè)新項(xiàng)目需要從舊項(xiàng)目摘出去,于是新配了一個(gè)環(huán)境,結(jié)果結(jié)果放到測(cè)試環(huán)境去的時(shí)候,他居然卡住了,而且沒有任何輸出就卡在圖形化界面了,生平第一次見。
解決
重新打了很多次的包,還是不行。??
真是一個(gè)bug能占我一天(我要堅(jiān)強(qiáng)),最后讓大佬看了一下,十分鐘就解決了。
這里發(fā)現(xiàn)的問題是因?yàn)槿罩镜呐渲糜袉栴},之前配置文件就那么幾個(gè),也沒注意到 logback-spring.xml 配置文件里面有一個(gè)環(huán)境的配置。
紅框?yàn)橹暗臏y(cè)試環(huán)境,綠框?yàn)檫@次新增的環(huán)境。
比如application-test.yml,那么這里配置的就是 name=“test”。
像這種卡住了,一般不會(huì)是說數(shù)據(jù)庫(kù)連不上,因?yàn)檫B不上就報(bào)sql錯(cuò)誤了。說什么 啟動(dòng)類加上 注解的,也試過。但是這個(gè)一點(diǎn)日志出不來的,肯定是和日志有關(guān)系。遇到不會(huì)的就要虛心去問。
sprinboot項(xiàng)目啟動(dòng)卡住,無(wú)任何異常信息
項(xiàng)目場(chǎng)景
SpringBoot項(xiàng)目啟動(dòng)的時(shí)候Console控制臺(tái)日志打印卡住,無(wú)任何異常信息打印
問題描述
之前項(xiàng)目是好的,但是后面經(jīng)人寫了一部分代碼之后,項(xiàng)目啟動(dòng)不了,SpringBoot項(xiàng)目啟動(dòng)時(shí)直接卡住,日志也不打印,也沒有具體的異常信息,某位同事折騰一天。
原因分析
之前我遇到過類似的問題?,F(xiàn)在我把我所有的問題分析列在下面:
有可能是改動(dòng)了pom.xml文件,項(xiàng)目沒有徹底更新,導(dǎo)致引入的jar存在版本問題或者根本沒有引入進(jìn)來
項(xiàng)目是Debug模式啟動(dòng),然后有一些特殊的斷點(diǎn)導(dǎo)致項(xiàng)目啟動(dòng)卡住
項(xiàng)目的目錄結(jié)構(gòu)變更,導(dǎo)致某些bean沒有被加載到?或者加載了多個(gè)相同的bean
某些異常沒有被捕獲到,同時(shí)啟動(dòng)類里面也沒有加上全局的try-catch,導(dǎo)致項(xiàng)目卡住
部分代碼需要隨程序自啟,使用@PostConstruct、InitializingBean、ApplicationRunner等方式實(shí)現(xiàn)項(xiàng)目初始化時(shí)加載,如果有遠(yuǎn)程連接,而且連接失敗或者異常了,沒有try-catch,也容易導(dǎo)致啟動(dòng)程序卡死。
解決方案
針對(duì)上述列出來的分析,我們可以采用以下解決方案,一步步嘗試
如果是pom.xml變更了沒生效,我們只需要對(duì)pom.xml 重新import即可,另外可以考慮清除idea緩存
如果是debug模式的斷點(diǎn)引起的話,去掉所有斷點(diǎn)再試試
如果是項(xiàng)目目錄結(jié)構(gòu)變更,這個(gè)maven clean一下,重新install 即可
如果可以變更啟動(dòng)類的話,建議在開發(fā)階段對(duì)啟動(dòng)類的main方法里面的代碼加上try-catch,這樣啟動(dòng)項(xiàng)目的時(shí)候就知道具體異常是什么
如果說分析哪些程序自啟的代碼導(dǎo)致項(xiàng)目啟動(dòng)卡住的話,我建議查看項(xiàng)目啟動(dòng)快照,具體如下:
分析當(dāng)前主線程到底因?yàn)槭裁纯ㄗ?waiting),比如我這里是因?yàn)閿?shù)據(jù)源配置的有問題導(dǎo)致卡住
最終解決方案:6、如果上述方案都無(wú)法解決問題,那么可以查看項(xiàng)目啟動(dòng)日志文件,一般和項(xiàng)目同級(jí)目錄或者有個(gè)log目錄存儲(chǔ),里面會(huì)記錄所有信息/異常信息
例如:這里是我同事的異常:
異常分析:是因?yàn)樗麖牧硗庖粋€(gè)項(xiàng)目copy過來的mapper.xml文件,之前用的是mybatis,現(xiàn)在項(xiàng)目用的ibatis,不識(shí)別<where>標(biāo)簽,ibatis只支持<dynamic prepend="where"> 來用
改成ibatis識(shí)別的方式即可。 這里注重給大家講怎么去找到并分析異常。
總結(jié)
項(xiàng)目啟動(dòng)卡住了,肯定是有異常原因存在,我們需要的是沉著冷靜,一步步找問題所在。另外就是大家在CV代碼時(shí),尤其是兩個(gè)不同的項(xiàng)目的時(shí)候,一定要注意細(xì)節(jié)啊!
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu)中的HashMap和HashSet詳解
HashMap和HashSet都是存儲(chǔ)在哈希桶之中,通過本文我們可以先了解一些哈希桶是什么,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2023-10-10淺談SpringMVC的攔截器(Interceptor)和Servlet 的過濾器(Filter)的區(qū)別與聯(lián)系 及Spr
這篇文章主要介紹了淺談SpringMVC的攔截器(Interceptor)和Servlet 的過濾器(Filter)的區(qū)別與聯(lián)系 及SpringMVC 的配置文件,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07java servlet 幾種頁(yè)面跳轉(zhuǎn)的方法
java servlet 幾種頁(yè)面跳轉(zhuǎn)的方法,需要的朋友可以參考一下2013-04-04使用spring?security?BCryptPasswordEncoder接入系統(tǒng)
這篇文章主要介紹了使用spring?security?BCryptPasswordEncoder接入系統(tǒng)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08JavaCV調(diào)用百度AI實(shí)現(xiàn)人臉檢測(cè)方法詳解
在檢測(cè)人臉數(shù)量、位置、性別、口罩等場(chǎng)景時(shí),可以考慮使用百度開放平臺(tái)提供的web接口,一個(gè)web請(qǐng)求就能完成檢測(cè)得到結(jié)果。本文就為大家介紹JavaCV如何調(diào)用百度AI實(shí)現(xiàn)最簡(jiǎn)單的人臉檢測(cè),需要的可以參考一下2022-01-01