資料介紹
軟件簡(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ǎng)址進(jìn)入快速開始并獲取更多詳細(xì)信息。
背景
日常使用 Java 開發(fā),常常會(huì)遇到包依賴沖突的問題,尤其當(dāng)工程應(yīng)用變得臃腫龐大,包沖突的問題也會(huì)變得更加棘手,導(dǎo)致各種各樣的報(bào)錯(cuò),例如LinkageError
, NoSuchMethodError
等;實(shí)際開發(fā)中,可以采用多種方法來解決包沖突問題,比較常見的是類似 SpringBoot 的做法,統(tǒng)一管理應(yīng)用所有依賴包的版本,保證這些三方包不存在依賴沖突;這種做法只能有效避免包沖突的問題,不能根本上解決包沖突的問題;如果某個(gè)應(yīng)用的確需要在運(yùn)行時(shí)使用兩個(gè)相互沖突的包,例如 protobuf2
和 protobuf3
,那么類似 SpringBoot 的做法依然解決不了問題;
為了徹底解決包沖突的問題,我們需要借助類隔離機(jī)制,使用不同的 Classloader 加載不同版本的三方依賴,進(jìn)而隔離包沖突問題;OSGI 作為業(yè)內(nèi)最出名的類隔離框架,自然是可以被用于解決上述包沖突問題,但是 OSGI 框架太過臃腫,功能繁雜;為了解決包沖突問題,引入 OSGI 框架,有牛刀殺雞之嫌,反而使工程變得更加復(fù)雜,不利于開發(fā);
SOFAArk 專注于解決類隔離問題,采用輕量級(jí)的類隔離方案來解決日常經(jīng)常遇到的包沖突問題,在螞蟻金服內(nèi)部服務(wù)于整個(gè) SOFABoot 技術(shù)體系,彌補(bǔ) SpringBoot 沒有的類隔離能力。實(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ù)語,有必要先說一下所謂的 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初衷是為了解決包沖突問題,那什么情況下可以使用 SOFAArk 以及如何使用呢? 假設(shè)如下場(chǎng)景,如果工程需要引入兩個(gè)三方包:A 和 B,但是 A 需要依賴版本號(hào)為 0.1 的 C 包,而恰好 B 需要依賴版本號(hào)為 0.2 的 C 包,且 C 包的這兩個(gè)版本無法兼容:
此時(shí),即可使用 SOFAArk 解決該依賴沖突問題;只需要把 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ì)象資料說明 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)和使用 1449次閱讀
- 類隔離的使用場(chǎng)景 455次閱讀
- 一個(gè)輕量級(jí)的權(quán)限認(rèn)證框架:Sa-Token 2203次閱讀
- 解讀Ⅰ類陶瓷電容器與Ⅱ類陶瓷電容器 1438次閱讀
- 一個(gè)純Python編寫的輕量級(jí)數(shù)據(jù)庫(kù) 856次閱讀
- 針對(duì)單片機(jī)開發(fā)的輕量級(jí)OTA組件 1428次閱讀
- TinyDB輕量級(jí)數(shù)據(jù)庫(kù)有哪些特點(diǎn)呢 1504次閱讀
- 一款適合初學(xué)者超輕量級(jí)C語言網(wǎng)絡(luò)庫(kù)—Dyad 2015次閱讀
- 輕量級(jí)Kubernetes-K3S工具介紹 2532次閱讀
- 容器——“輕量級(jí)”的虛擬化 7168次閱讀
- 全球首款輕量級(jí)機(jī)械臂已經(jīng)出現(xiàn)了! 7535次閱讀
- Java數(shù)組的常用方法_Java:數(shù)組工具類Arrays類的常用方法的用法及代碼 2930次閱讀
- spring框架中定時(shí)器使用與配置 1793次閱讀
- 谷歌開源TFGAN輕量級(jí)的工具庫(kù) 目的是讓訓(xùn)練和評(píng)估GAN變得更加簡(jiǎn)單 4963次閱讀
- 谷歌開發(fā)一個(gè)輕量級(jí)的庫(kù)——TFGAN 它可以讓生成對(duì)抗網(wǎng)絡(luò)更易于實(shí)驗(yàn) 5541次閱讀
下載排行
本周
- 1DD3118電路圖紙資料
- 0.08 MB | 1次下載 | 免費(fèi)
- 2AD庫(kù)封裝庫(kù)安裝教程
- 0.49 MB | 1次下載 | 免費(fèi)
- 3PC6206 300mA低功耗低壓差線性穩(wěn)壓器中文資料
- 1.12 MB | 1次下載 | 免費(fèi)
- 4網(wǎng)絡(luò)安全從業(yè)者入門指南
- 2.91 MB | 1次下載 | 免費(fèi)
- 5DS-CS3A P00-CN-V3
- 618.05 KB | 1次下載 | 免費(fèi)
- 6海川SM5701規(guī)格書
- 1.48 MB | 次下載 | 免費(fèi)
- 7H20PR5電磁爐IGBT功率管規(guī)格書
- 1.68 MB | 次下載 | 1 積分
- 8IP防護(hù)等級(jí)說明
- 0.08 MB | 次下載 | 免費(fèi)
本月
- 1貼片三極管上的印字與真實(shí)名稱的對(duì)照表詳細(xì)說明
- 0.50 MB | 103次下載 | 1 積分
- 2涂鴉各WiFi模塊原理圖加PCB封裝
- 11.75 MB | 89次下載 | 1 積分
- 3錦銳科技CA51F2 SDK開發(fā)包
- 24.06 MB | 43次下載 | 1 積分
- 4錦銳CA51F005 SDK開發(fā)包
- 19.47 MB | 19次下載 | 1 積分
- 5PCB的EMC設(shè)計(jì)指南
- 2.47 MB | 16次下載 | 1 積分
- 6HC05藍(lán)牙原理圖加PCB
- 15.76 MB | 13次下載 | 1 積分
- 7802.11_Wireless_Networks
- 4.17 MB | 12次下載 | 免費(fèi)
- 8蘋果iphone 11電路原理圖
- 4.98 MB | 6次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935127次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191390次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183342次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81588次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65989次下載 | 10 積分
評(píng)論