一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>SOFAArk輕量級(jí)Java類隔離容器

SOFAArk輕量級(jí)Java類隔離容器

2022-05-10 | zip | 42.92 MB | 次下載 | 2積分

資料介紹

授權(quán)協(xié)議 Apache 2.0
開發(fā)語言 Java
操作系統(tǒng) 跨平臺(tái)
軟件類型 開源軟件

軟件簡(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è)相互沖突的包,例如 protobuf2protobuf3,那么類似 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 PluginArk Biz; 運(yùn)行時(shí)邏輯結(jié)構(gòu)圖如下:

poYBAGJpIgWAQh_UAAF99q6U7GA594.png

在介紹這三個(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 PluginArk Biz 運(yùn)行在 Ark 容器之上;容器具備管理多插件、多應(yīng)用的功能;容器啟動(dòng)成功后,會(huì)自動(dòng)解析 classpath 包含的 Ark PluginArk 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 PluginArk 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 PluginArk 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è)版本無法兼容:

pYYBAGJpIgaANAz4AADa53M6yWg663.png

此時(shí),即可使用 SOFAArk 解決該依賴沖突問題;只需要把 A 和版本為 0.1 的 C 包一起打包成一個(gè) Ark Plugin,然后讓應(yīng)用工程引入該插件依賴即可。

?

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1DD3118電路圖紙資料
  2. 0.08 MB   |  1次下載  |  免費(fèi)
  3. 2AD庫(kù)封裝庫(kù)安裝教程
  4. 0.49 MB   |  1次下載  |  免費(fèi)
  5. 3PC6206 300mA低功耗低壓差線性穩(wěn)壓器中文資料
  6. 1.12 MB   |  1次下載  |  免費(fèi)
  7. 4網(wǎng)絡(luò)安全從業(yè)者入門指南
  8. 2.91 MB   |  1次下載  |  免費(fèi)
  9. 5DS-CS3A P00-CN-V3
  10. 618.05 KB  |  1次下載  |  免費(fèi)
  11. 6海川SM5701規(guī)格書
  12. 1.48 MB  |  次下載  |  免費(fèi)
  13. 7H20PR5電磁爐IGBT功率管規(guī)格書
  14. 1.68 MB   |  次下載  |  1 積分
  15. 8IP防護(hù)等級(jí)說明
  16. 0.08 MB   |  次下載  |  免費(fèi)

本月

  1. 1貼片三極管上的印字與真實(shí)名稱的對(duì)照表詳細(xì)說明
  2. 0.50 MB   |  103次下載  |  1 積分
  3. 2涂鴉各WiFi模塊原理圖加PCB封裝
  4. 11.75 MB   |  89次下載  |  1 積分
  5. 3錦銳科技CA51F2 SDK開發(fā)包
  6. 24.06 MB   |  43次下載  |  1 積分
  7. 4錦銳CA51F005 SDK開發(fā)包
  8. 19.47 MB   |  19次下載  |  1 積分
  9. 5PCB的EMC設(shè)計(jì)指南
  10. 2.47 MB   |  16次下載  |  1 積分
  11. 6HC05藍(lán)牙原理圖加PCB
  12. 15.76 MB   |  13次下載  |  1 積分
  13. 7802.11_Wireless_Networks
  14. 4.17 MB   |  12次下載  |  免費(fèi)
  15. 8蘋果iphone 11電路原理圖
  16. 4.98 MB   |  6次下載  |  2 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935127次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233089次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費(fèi)下載
  8. 340992  |  191390次下載  |  10 積分
  9. 5十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
  10. 158M  |  183342次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81588次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費(fèi)下載
  14. 0.02 MB  |  73815次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65989次下載  |  10 積分