資料介紹
軟件簡(jiǎn)介
SOFAArk 是一款基于 Java 實(shí)現(xiàn)的輕量級(jí)類隔離容器,由螞蟻金服公司開源貢獻(xiàn);主要為應(yīng)用程序提供類隔離和依賴包隔離的能力;基于 Fat Jar 技術(shù),應(yīng)用可以被打包成一個(gè)自包含可運(yùn)行的 Fat Jar,應(yīng)用既可以是簡(jiǎn)單的單模塊 Java 應(yīng)用也可以是 Spring Boot 應(yīng)用???a>訪問(wèn)網(wǎng)址進(jìn)入快速開始并獲取更多詳細(xì)信息。
背景
日常使用 Java 開發(fā),常常會(huì)遇到包依賴沖突的問(wèn)題,尤其當(dāng)工程應(yīng)用變得臃腫龐大,包沖突的問(wèn)題也會(huì)變得更加棘手,導(dǎo)致各種各樣的報(bào)錯(cuò),例如LinkageError
, NoSuchMethodError
等;實(shí)際開發(fā)中,可以采用多種方法來(lái)解決包沖突問(wèn)題,比較常見(jiàn)的是類似 SpringBoot 的做法,統(tǒng)一管理應(yīng)用所有依賴包的版本,保證這些三方包不存在依賴沖突;這種做法只能有效避免包沖突的問(wèn)題,不能根本上解決包沖突的問(wèn)題;如果某個(gè)應(yīng)用的確需要在運(yùn)行時(shí)使用兩個(gè)相互沖突的包,例如 protobuf2
和 protobuf3
,那么類似 SpringBoot 的做法依然解決不了問(wèn)題;
為了徹底解決包沖突的問(wèn)題,我們需要借助類隔離機(jī)制,使用不同的 Classloader 加載不同版本的三方依賴,進(jìn)而隔離包沖突問(wèn)題;OSGI 作為業(yè)內(nèi)最出名的類隔離框架,自然是可以被用于解決上述包沖突問(wèn)題,但是 OSGI 框架太過(guò)臃腫,功能繁雜;為了解決包沖突問(wèn)題,引入 OSGI 框架,有牛刀殺雞之嫌,反而使工程變得更加復(fù)雜,不利于開發(fā);
SOFAArk 專注于解決類隔離問(wèn)題,采用輕量級(jí)的類隔離方案來(lái)解決日常經(jīng)常遇到的包沖突問(wèn)題,在螞蟻金服內(nèi)部服務(wù)于整個(gè) SOFABoot 技術(shù)體系,彌補(bǔ) SpringBoot 沒(méi)有的類隔離能力。實(shí)際上,SOFAArk 是一個(gè)通用的輕量級(jí)類隔離框架,并不限于 SpringBoot 應(yīng)用,也可以和其他的 Java 開發(fā)框架集成;
原理
SOFAArk 框架包含有三個(gè)概念,Ark Container
, Ark Plugin
和 Ark Biz
; 運(yùn)行時(shí)邏輯結(jié)構(gòu)圖如下:
在介紹這三個(gè)概念之前,為了統(tǒng)一術(shù)語(yǔ),有必要先說(shuō)一下所謂的 Ark 包
;Ark 包是滿足特定目錄格式要求的 Executed Fat Jar
,使用官方提供的 Maven
插件 sofa-ark-maven-plugin
可以將工程應(yīng)用打包成一個(gè)標(biāo)準(zhǔn)格式的 Ark 包
;使用命令 java -jar application.jar
即可在 Ark 容器之上啟動(dòng)應(yīng)用;Ark 包
通常包含 Ark Container
、Ark Plugin
、 Ark Biz
;以下我們針對(duì)這三個(gè)概念簡(jiǎn)單做下名詞解釋:
-
Ark Container
: Ark 容器,負(fù)責(zé)整個(gè)運(yùn)行時(shí)的管理;Ark Plugin
和Ark Biz
運(yùn)行在 Ark 容器之上;容器具備管理多插件、多應(yīng)用的功能;容器啟動(dòng)成功后,會(huì)自動(dòng)解析 classpath 包含的Ark Plugin
和Ark Biz
依賴,完成隔離加載并按優(yōu)先級(jí)依次啟動(dòng)之; -
Ark Plugin
: Ark 插件,滿足特定目錄格式要求的Fat Jar
,使用官方提供的Maven
插件sofa-ark-plugin-maven-plugin
可以將一個(gè)或多個(gè)普通的Java Jar
包打包成一個(gè)標(biāo)準(zhǔn)格式的Ark Plugin
;Ark Plugin
會(huì)包含一份配置文件,通常包括插件類導(dǎo)入導(dǎo)出配置、插件啟動(dòng)優(yōu)先級(jí)等;運(yùn)行時(shí),Ark 容器會(huì)使用獨(dú)立的PluginClassLoader
加載插件,并根據(jù)插件配置構(gòu)建類加載索引表,從而使插件與插件、插件與應(yīng)用之間相互隔離; -
Ark Biz
: Ark 業(yè)務(wù)模塊,滿足特定目錄格式要求的Fat Jar
,使用官方提供的Maven
插件sofa-ark-maven-plugin
可以將工程應(yīng)用打包成一個(gè)標(biāo)準(zhǔn)格式的Ark-Biz
包;是工程應(yīng)用模塊及其依賴包的組織單元,包含應(yīng)用啟動(dòng)所需的所有依賴和配置;
在運(yùn)行時(shí),Ark Container
優(yōu)先啟動(dòng),自動(dòng)解析 classpath 包含的 Ark Plugin
和 Ark Biz
,并讀取他們的配置,構(gòu)建類加載索引關(guān)系;然后使用獨(dú)立的 Classloader 加載他們并按優(yōu)先級(jí)配置依次啟動(dòng);需要指出的是,Ark Plugin
優(yōu)先 Ark Biz
被加載啟動(dòng);Ark Plugin
之間是雙向類索引關(guān)系,即可以相互委托對(duì)方加載所需的類;Ark Plugin
和 Ark Biz
是單向類索引關(guān)系,即只允許 Ark Biz
索引 Ark Plugin
加載的類,反之則不允許。
場(chǎng)景
SOFAArk初衷是為了解決包沖突問(wèn)題,那什么情況下可以使用 SOFAArk 以及如何使用呢? 假設(shè)如下場(chǎng)景,如果工程需要引入兩個(gè)三方包:A 和 B,但是 A 需要依賴版本號(hào)為 0.1 的 C 包,而恰好 B 需要依賴版本號(hào)為 0.2 的 C 包,且 C 包的這兩個(gè)版本無(wú)法兼容:
此時(shí),即可使用 SOFAArk 解決該依賴沖突問(wèn)題;只需要把 A 和版本為 0.1 的 C 包一起打包成一個(gè) Ark Plugin
,然后讓應(yīng)用工程引入該插件依賴即可。
- PSoC NeoPixel Easy輕量級(jí)庫(kù)
- 嵌入式Linux容器技術(shù)
- 輕量級(jí)的SDN數(shù)據(jù)包轉(zhuǎn)發(fā)驗(yàn)證方案 10次下載
- 基于Feistel結(jié)構(gòu)的超輕量級(jí)分組密碼算法 4次下載
- 基于輕量級(jí)虛擬化的LDDoS仿真攻防方法 6次下載
- 輕量級(jí)分布式機(jī)器學(xué)習(xí)系統(tǒng)及算法 16次下載
- 基于YOLO改進(jìn)的輕量級(jí)交通標(biāo)識(shí)檢測(cè)模型 12次下載
- 一種輕量級(jí)時(shí)間卷積網(wǎng)絡(luò)設(shè)計(jì)方案 6次下載
- Protothreads極輕量級(jí)系統(tǒng)的詳細(xì)資料簡(jiǎn)介
- Java教程之零點(diǎn)起飛學(xué)Java的類與對(duì)象資料說(shuō)明 14次下載
- 基于ARM的輕量級(jí)TCPIP協(xié)議棧的移植及應(yīng)用 54次下載
- 基于MVC架構(gòu)的輕量級(jí)工作流引擎設(shè)計(jì) 0次下載
- 輕量級(jí)工作流引擎架構(gòu)設(shè)計(jì) 0次下載
- 輕量級(jí)RFID安全協(xié)議 22次下載
- Java的類 0次下載
- Linux輕量級(jí)工具集合Busybox的特點(diǎn)和使用 1185次閱讀
- 類隔離的使用場(chǎng)景 351次閱讀
- 一個(gè)輕量級(jí)的權(quán)限認(rèn)證框架:Sa-Token 1525次閱讀
- 解讀Ⅰ類陶瓷電容器與Ⅱ類陶瓷電容器 1130次閱讀
- 一個(gè)純Python編寫的輕量級(jí)數(shù)據(jù)庫(kù) 700次閱讀
- 針對(duì)單片機(jī)開發(fā)的輕量級(jí)OTA組件 1199次閱讀
- TinyDB輕量級(jí)數(shù)據(jù)庫(kù)有哪些特點(diǎn)呢 1329次閱讀
- 一款適合初學(xué)者超輕量級(jí)C語(yǔ)言網(wǎng)絡(luò)庫(kù)—Dyad 1594次閱讀
- 輕量級(jí)Kubernetes-K3S工具介紹 2298次閱讀
- 容器——“輕量級(jí)”的虛擬化 6950次閱讀
- 全球首款輕量級(jí)機(jī)械臂已經(jīng)出現(xiàn)了! 7399次閱讀
- Java數(shù)組的常用方法_Java:數(shù)組工具類Arrays類的常用方法的用法及代碼 2849次閱讀
- spring框架中定時(shí)器使用與配置 1668次閱讀
- 谷歌開源TFGAN輕量級(jí)的工具庫(kù) 目的是讓訓(xùn)練和評(píng)估GAN變得更加簡(jiǎn)單 4811次閱讀
- 谷歌開發(fā)一個(gè)輕量級(jí)的庫(kù)——TFGAN 它可以讓生成對(duì)抗網(wǎng)絡(luò)更易于實(shí)驗(yàn) 5412次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
- 1.06 MB | 532次下載 | 免費(fèi)
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費(fèi)
- 3TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費(fèi)
- 5元宇宙深度解析—未來(lái)的未來(lái)-風(fēng)口還是泡沫
- 6.40 MB | 227次下載 | 免費(fèi)
- 6迪文DGUS開發(fā)指南
- 31.67 MB | 194次下載 | 免費(fèi)
- 7元宇宙底層硬件系列報(bào)告
- 13.42 MB | 182次下載 | 免費(fèi)
- 8FP5207XR-G1中文應(yīng)用手冊(cè)
- 1.09 MB | 178次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33566次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21549次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德?tīng)栔?/a>
- 0.00 MB | 6656次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537798次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191187次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183279次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論
查看更多