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