詳解pom如何引入非Maven工程的jar包
背景
系統(tǒng)遷移從某個公有云遷移到私有云,因為現(xiàn)在國內(nèi)大力推行國產(chǎn)化,所以我們這次遷移有兩個國產(chǎn)化的東西(這里不包括硬件)。第一個是操作系統(tǒng)采用了歐拉操作系統(tǒng)(華為爸爸出產(chǎn)據(jù)說已捐),第二個就是數(shù)據(jù)庫采用了goldendb。
這次記錄這個問題主要是因為使用提供的goldendb的驅(qū)動連接不上數(shù)據(jù)庫,啟動的時候報錯。這次我們使用的對方提供的gdb_mysql-connector-java-5.1.46.28.jar這個驅(qū)動,而且是一個普通工程打成的jar包。
maven工程打包結(jié)構(gòu)中包含pom文件:
而普通工程打包后,是不存在pom文件的:
問題
這個jar包如何使用,用maven私庫管理?直接引用?當(dāng)作外部jar包加載?這個時候發(fā)現(xiàn)自己的儲備已經(jīng)不夠用。
分析
因為本地沒有g(shù)oldendb只能使用mysql8做測試,驅(qū)動使用gdb_mysql-connector-java-5.1.46.28.jar。
方案一:通過web頁面上傳jar包到nexus私庫中,使用pom依賴引入,失敗現(xiàn)象下載的jar是空包;
方案二:使用java -jar -Dload.path,但百度告訴我應(yīng)該使用java -cp path/to/external.jar -jar yourJarFile.jar;
方案三:使用maven命令將驅(qū)動jar包推入nexus私服中;
方案四:在項目中的pom文件中使用如下配置,引入jar包;
方案一
使用管理員賬號登錄自己或者公司搭建的nexus私服,找到左邊upload菜單,選中目標(biāo)倉庫進(jìn)行上傳界面如下(圖片為nexus3的界面僅供參考):
*注意: *最后的packaging填上jar
上傳是成功的,因為在倉庫里是能找到對應(yīng)的包和內(nèi)容的(網(wǎng)絡(luò)圖片僅供參考):
但是,下載的時候卻是不成功的,因為每次下載下來的依賴包只有6kb:
然而服務(wù)器上是975kb:
那就說明普通java工程打jar不能通過這種方式直接上傳,可能使用maven命令將驅(qū)動jar包推入nexus私服中,只是猜測需要驗證,方案一行不通。
方案四
新建一個springboot maven項目,在application中增加數(shù)據(jù)源的配置:
spring: datasource: username: rrbbd password: gfdgdf driver-class-name: com.goldendb.jdbc.Driver url: jdbc:goldendb:loadbalance://localhost:3306/monster?useCursorFetch=false&useSSL=false&cachePrepStmts=true&prepStmtCacheSqlLimit=20480&prepStmtCacheSize=2000&characterEncoding=utf8&queryTimeoutKillsConnection=true&isConnectionLevel=true&connectTimeout=60000&shadowThreadSwitch=False
使用了大佬提供的maven配置進(jìn)行測試,在工程resources目錄下創(chuàng)建lib目錄,通過在pom中增加如下配置來引入jar包:
<dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.46</version> <scope>system</scope> <systemPath>${project.basedir}/src/main/resources/lib/gdb_mysql-connector-java-5.1.46.28.jar</systemPath> </dependency>
*注意: *這里的groupId、artifactId、version可隨便命名
然后根據(jù)自己的表創(chuàng)建一個jdbc查詢語句,用于測試:
Connection con = dataSource.getConnection(); Statement stmt = con.createStatement(); String sql = "select * from t_user;"; ResultSet rs = stmt.executeQuery(sql); ResultSetMetaData metaData = rs.getMetaData(); while (rs.next()) { int id = rs.getInt(1); String name = rs.getString(2); log.info("id:{}", id); log.info("name:{}", name); } con.close();
工程的目錄結(jié)構(gòu):
異常報錯
第一次在idea中啟動報java.sql.SQLException: Unable to load authentication plugin 'caching_sha2_password'.
問題原因
這是mysql 8.0版本才出現(xiàn)的問題,原因是mysql 8.0 默認(rèn)使用 caching_sha2_password 身份驗證機(jī)制 —— 從原來的 mysql_native_password 更改為 caching_sha2_password。所以一般這種報錯由于本地的MySQL使用的是最新版8.0版本,而打包的項目使用的則是比較低的版本,可以解釋說是版本沖突產(chǎn)生的問題。
解決方法
方案1:安裝較低版本的MySQL
方案2:修改身份驗證機(jī)制:
alter user 'root'@'localhost' identified by '你的密碼' password expire never; ? alter user 'root'@'localhost' identified with mysql_native_password by '你的密碼' ? flush privileges;
解決認(rèn)證問題,在idea中啟動能夠成功連接數(shù)據(jù)庫并讀取數(shù)據(jù)如下圖:
打包使用命令啟動發(fā)現(xiàn),任然報找不到驅(qū)動:
檢查jar包中驅(qū)動已經(jīng)打包進(jìn)去了:
大佬又花了幾分鐘搞了個測試,增加了一個springboot maven打包插件的參數(shù),如下:
再次打包使用java -jar也成功連接上了mysql數(shù)據(jù)庫,同時也讀出來了數(shù)據(jù)。
結(jié)論
方案二和方案三還沒有進(jìn)行測試后續(xù)再補(bǔ)充,總歸還是自己對maven不夠了解。至于手動上傳普通java jar包到nexus無法下載,我猜可能因為下載的機(jī)制需要驗證groupId、artifactId、version與jar包中的pom文件中的定義一樣。也就是手動上傳至少需要這個jar包本身就是一個maven工程打的包含有pom文件,但這個猜測也需要驗證。
總結(jié)
一開始,使用驅(qū)動直接在項目中替換,改apollo配置嘗試啟動。改來改去我總覺得排查問題的干擾因素太多,那為什么不簡單一點(diǎn)呢?我們直接寫一個demo用jdbc查詢一個測試表,將數(shù)據(jù)展示出來。這樣就簡單多了,我們關(guān)注問題本身,排除其他因素的干擾。讀不到驅(qū)動,不是包沒有引入,就是配置有問題,這樣我們可以集中精力去做更多的嘗試。如果包也引入了,配置也沒問題,那再排查其他問題。我認(rèn)為這種控制變量因素最小化,可以幫助我們來更快地定位到問題以及解決問題。記錄一下問題排查的過程,方便以后自己和別人查閱。如果文章有錯誤的描述或者需要修正可以留言聯(lián)系我。
遺留問題
問題雖然解決了,但還遺留兩個問題。
問題1:普通工程的jar是否可以使用nexus進(jìn)行管理?是否使用maven命令叫jar推到私庫里方式就可以了呢?這個問題還需要驗證。
問題2:是否可以使用啟動命令java上-cp來加載外部jar依賴?這種方式是否能是程序讀到依賴的驅(qū)動也還需要驗證。
以上就是詳解pom如何引入非Maven工程的jar包的詳細(xì)內(nèi)容,更多關(guān)于pom引入非Maven jar包的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Springboot之如何統(tǒng)計代碼執(zhí)行耗時時間
這篇文章主要介紹了Springboot之如何統(tǒng)計代碼執(zhí)行耗時時間問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03Java中Queue的poll()和remove()區(qū)別詳解
這篇文章主要介紹了Java中Queue的poll()和remove()區(qū)別詳解,Queue接口提供了許多方法,其中poll()和remove()是兩個常用的方法,它們的區(qū)別在于,當(dāng)隊列為空時,poll()方法返回null,而remove()方法會拋出,需要的朋友可以參考下2023-07-07簡單談?wù)凧VM、JRE和JDK的區(qū)別與聯(lián)系
簡單的說JDK是用于開發(fā)的而JRE是用于運(yùn)行Java程序的。JDK和JRE都包含了JVM,從而使得我們可以運(yùn)行Java程序。JVM是Java編程語言的核心并且具有平臺獨(dú)立性。2016-05-05