Maven assembly打包文件被覆盖问题
Maven的assembly插件使用:
最近在做一個(gè)小工程,利用java啟動(dòng)運(yùn)行。
為了簡(jiǎn)單方便使用運(yùn)行,利用maven的assembly將需要使用的jar都打包到一個(gè)jar中。這樣無論拷貝到哪里,只有運(yùn)行就可以,不用需要任何配置。
配置時(shí)指定mainClass,運(yùn)行java的main函數(shù)時(shí)則可以不用指定包含main函數(shù)的類路徑名。如運(yùn)行下面的jar文件則非常簡(jiǎn)單方便(后臺(tái)運(yùn)行):nohup?java?-jar?CalculateScore.jar?&
第一步:需要在pom的xml中添加配置;
第二步:配置maven的Run?Configurations,Goals配置成assembly:assembly即可。
上面的過程一直在使用,很正常。但最近的小應(yīng)用卻出了問題:
打出的jar包不產(chǎn)生日志文件,具體說是不生成log4j的日志信息,程序運(yùn)行正常也不報(bào)錯(cuò),任何提示都沒有。
?
網(wǎng)上各種查詢,沒有結(jié)果。為了解決問題就各種嘗試。
?
腦子里一直有疑問:以前的都正常使用,都可以打印日志,為什么這個(gè)就不行呢?
各種嘗試都不行,于是就反編譯jar包來看。結(jié)果發(fā)現(xiàn)log4j.properties文件不是自己的那個(gè)文件,不知道是哪個(gè)包里的,而自己程序中都使用的Logger.getLogger(name)的形式,所以都無法打印日志信息。
?
問題來了,為什么不是自己的那個(gè)log4j配置文件呢?
Maven打包的時(shí)候Console中都有日志信息,仔細(xì)查看發(fā)現(xiàn),多次提示log4j的配置已經(jīng)加入并跳過。
于是猜想:一定是打包的過程中,先加載了其他jar中的log4j的配置文件,而以后的包括自己應(yīng)用中的log4j的配置文件都被忽略了。
?
可是問題又來了,自己以前使用同樣的方式,也使用了很多第三方包,都包含有log4j的配置文件,為什么都沒有問題呢?查看以前的打的包,log4j的配置文件都是自己工程中配置的,這是為什么呢?
?
于是就開始比較打包的配置過程是否有差別,又有新發(fā)現(xiàn):
Maven打包的Run?Configurations配置中有項(xiàng)Base?directory,這里配置有問題。
如下面的兩張圖所示:
如果Base?directory中配置的是通過Browse?Workspace選擇的工程就會(huì)產(chǎn)生上面的問題;
如果Base?directory中配置的是通過Browse?File?System選擇的文件地址路徑就不會(huì)產(chǎn)生上面的問題。
具體為什么會(huì)出現(xiàn)這種情況,有待研究。
?
會(huì)產(chǎn)生問題的配置方式:
?
不會(huì)產(chǎn)生問題的配置方式:
總結(jié)
以上是生活随笔為你收集整理的Maven assembly打包文件被覆盖问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 管理经济分析05:并购、价格歧视、四个市
- 下一篇: 使用Fiddler对手机APP抓包渗透测