一個(gè)項(xiàng)目使用兩個(gè)不同版本的jar包

問(wèn)題場(chǎng)景

??現(xiàn)在很多工程為了功能擴(kuò)展猾警,都給出了插件化的方式孔祸。只需要用戶配置好配置文件,提供好需要的jar包发皿,就能完成相應(yīng)功能〈藁郏現(xiàn)在項(xiàng)目一般都離不開(kāi)數(shù)據(jù)庫(kù),自己本身的項(xiàng)目就會(huì)帶這驅(qū)動(dòng)包穴墅,但是也會(huì)有這樣的一種需求惶室,就是數(shù)據(jù)額外存儲(chǔ)的定制化温自,當(dāng)產(chǎn)生的數(shù)據(jù)在自己項(xiàng)目的流程中不滿足現(xiàn)在使用。例如做報(bào)表皇钞,項(xiàng)目本身產(chǎn)生數(shù)據(jù)悼泌,但是需要把里面的一部分?jǐn)?shù)據(jù)拿出來(lái)和其他文本數(shù)據(jù)結(jié)合,產(chǎn)生新的數(shù)據(jù)夹界」堇铮或者現(xiàn)有的數(shù)據(jù)進(jìn)行時(shí)間的整合,直接變成周數(shù)據(jù)可柿,月數(shù)據(jù)鸠踪,年數(shù)據(jù)。這些都是需要根據(jù)不同用戶自己設(shè)定的趾痘。這些數(shù)據(jù)往往是需要另外的數(shù)據(jù)庫(kù)的慢哈,這就帶來(lái)了一個(gè)問(wèn)題,項(xiàng)目本身有一個(gè)jar包永票,例如Mysql4.5的卵贱,客戶想組織信息存入mysql5.5,jar包的類是相同的侣集,這樣就帶來(lái)了驅(qū)動(dòng)加載的問(wèn)題键俱,因?yàn)轭惖南嗤模因?qū)動(dòng)不是完全不兼容世分,而是在使用上會(huì)出問(wèn)題编振。典型的就是ojdbc14,用這個(gè)版本的驅(qū)動(dòng)建立數(shù)據(jù)庫(kù)使用語(yǔ)句池緩存會(huì)有問(wèn)題臭埋,ojdbc5踪央,6就沒(méi)事。(畢竟語(yǔ)句池緩存能帶來(lái)性能上優(yōu)化瓢阴,不能說(shuō)為了兼容驅(qū)動(dòng)放棄性能畅蹂,而且其他潛在的問(wèn)題還沒(méi)有暴露)。

問(wèn)題分析

??雙親委派模式的是好處是Java類隨著它的類加載器一起具備了一種帶有優(yōu)先級(jí)的層次關(guān)系荣恐,通過(guò)這種層級(jí)關(guān)可以避免類的重復(fù)加載液斜,當(dāng)父親已經(jīng)加載了該類時(shí),就沒(méi)有必要子ClassLoader再加載一次叠穆。其次是考慮到安全因素少漆,java核心api中定義類型不會(huì)被隨意替換,假設(shè)通過(guò)網(wǎng)絡(luò)傳遞一個(gè)名為java.lang.Integer的類硼被,通過(guò)雙親委托模式傳遞到啟動(dòng)類加載器示损,而啟動(dòng)類加載器在核心JavaAPI發(fā)現(xiàn)這個(gè)名字的類,發(fā)現(xiàn)該類已被加載嚷硫,并不會(huì)重新加載網(wǎng)絡(luò)傳遞的過(guò)來(lái)的java.lang.Integer屎媳,而直接返回已加載過(guò)的Integer.class夺溢,這樣便可以防止核心API庫(kù)被隨意篡改。雙親委派的這些特性導(dǎo)致一個(gè)程序想要加載兩個(gè)不同版本包時(shí)烛谊,由于已近記載了一個(gè)包,另一個(gè)不回加載嘉汰。

實(shí)現(xiàn)

??首先需要一個(gè)違背雙親委托的classloader丹禀,

破壞雙親委托機(jī)制的classloader

????????不論你是class.forname,還是loadclass方法的調(diào)用,最后都是要調(diào)用loadClass的鞋怀,所以這里一定要重寫(xiě)這個(gè)方法双泪,這里就要加入破壞雙親委托機(jī)制的邏輯。先從緩存找是否已經(jīng)加載了class密似,對(duì)已經(jīng)加載的就直接返回焙矛,防止重復(fù)加載。此處調(diào)用了findClass方法残腌,findClass是可以覆寫(xiě)的村斟,這里為了簡(jiǎn)潔的實(shí)現(xiàn),就不再覆寫(xiě)了抛猫。

????????classloader如果有重復(fù)的jar包蟆盹,findClass找到資源后會(huì)通過(guò)defineClass(String name, Resource res)來(lái)加載類,這里最后會(huì)調(diào)用getPackage來(lái)獲取包闺金。

覆寫(xiě) getPackage方法

????????這個(gè)方法逾滥,先從已經(jīng)加載的包中查找,如果沒(méi)有就先從父classloader找败匹,最后又進(jìn)行了雙親委托機(jī)制寨昙。所以這個(gè)地方也需要覆寫(xiě)。覆寫(xiě)直接返回空掀亩。在后面的判斷中舔哪,如果此處返回null,后續(xù)就會(huì)重新新建一個(gè)對(duì)象归榕,然后放入一個(gè)緩存結(jié)構(gòu)尸红,還是一個(gè)hashmap,?為空的結(jié)果只是更新一下緩存刹泄。

? ? 自定義的classloader很好的保證了我們加載的安全性外里,因?yàn)榈刂肥俏覀冎付ǖ摹?/p>

導(dǎo)入兩個(gè)不同版本的jdbc包,并獲取connection

通過(guò)DriverManager加載在項(xiàng)目里的包特石,通過(guò)自定義的driver加載另一個(gè)版本的包盅蝗,兩個(gè)包之間互不影響,都可以獲取到j(luò)dbc鏈接姆蘸。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末墩莫,一起剝皮案震驚了整個(gè)濱河市芙委,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌狂秦,老刑警劉巖灌侣,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異裂问,居然都是意外死亡侧啼,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人朋贬,你說(shuō)我怎么就攤上這事∧纳螅” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵虑瀑,是天一觀的道長(zhǎng)湿滓。 經(jīng)常有香客問(wèn)我,道長(zhǎng)缴川,這世上最難降的妖魔是什么茉稠? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮把夸,結(jié)果婚禮上而线,老公的妹妹穿的比我還像新娘。我一直安慰自己恋日,他們只是感情好膀篮,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著岂膳,像睡著了一般誓竿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上谈截,一...
    開(kāi)封第一講書(shū)人閱讀 49,950評(píng)論 1 291
  • 那天筷屡,我揣著相機(jī)與錄音,去河邊找鬼簸喂。 笑死毙死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的喻鳄。 我是一名探鬼主播扼倘,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼除呵!你這毒婦竟也來(lái)了再菊?” 一聲冷哼從身側(cè)響起爪喘,我...
    開(kāi)封第一講書(shū)人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎纠拔,沒(méi)想到半個(gè)月后秉剑,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绿语,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年秃症,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吕粹。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖岗仑,靈堂內(nèi)的尸體忽然破棺而出匹耕,到底是詐尸還是另有隱情,我是刑警寧澤荠雕,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布稳其,位于F島的核電站,受9級(jí)特大地震影響炸卑,放射性物質(zhì)發(fā)生泄漏既鞠。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一盖文、第九天 我趴在偏房一處隱蔽的房頂上張望嘱蛋。 院中可真熱鬧,春花似錦五续、人聲如沸洒敏。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)凶伙。三九已至,卻和暖如春它碎,著一層夾襖步出監(jiān)牢的瞬間函荣,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工扳肛, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留傻挂,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓敞峭,卻偏偏與公主長(zhǎng)得像踊谋,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子旋讹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容