碰到個奇葩事啊,一個spring的項目拿到客戶現場部署到resin4中,啟動後各種報無法註入bean,找不到bean的問題.出現大量下圖的錯誤: 除了系統,其他的jdk版本,resin版本,程式包都是在相同測試環境成功部署測試過的,無任何問題.所以想當然的認為可能拿過去的包有問題,馬上本地resin ...
碰到個奇葩事啊,一個spring的項目拿到客戶現場部署到resin4中,啟動後各種報無法註入bean,找不到bean的問題.出現大量下圖的錯誤:
nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type ...
除了系統,其他的jdk版本,resin版本,程式包都是在相同測試環境成功部署測試過的,無任何問題.所以想當然的認為可能拿過去的包有問題,馬上本地resin測試了一下程式包,果然也是各種報錯.哎~馬上重新打包再部署還是報錯..難道是resin的問題?本地恰巧有一個老版本的resin4.0.13,部署上去一看,正常的...看來果然是resin的問題..
本著bug應該在新版被修複的想法,馬上下載最新resin4.0.49,部署依然報錯.把測試環境的resin下到本地運行也報錯..我的天,這什麼鬼~
雖然能確定是resin的問題,但是到底問題出在哪裡呢?回憶一下無法註入bean,那麼肯定是spring初始化配置文件時,掃描載入各種bean的時候出錯,既然找不到,那麼肯定是當時沒有載入進去.檢查一下配置文件web.xml:
<context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext*.xml</param-value> </context-param>
突然想到一種可能,由於寫的是通配符的形式,會不會這裡有些問題導致配置文件沒有載入到呢?馬上改為逗號分隔具體文件名的形式後,重啟resin錯誤消失~到此故障解除...
補:期間是試過tomcat部署的,也是沒有任何問題.