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

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

3天內(nèi)不再提示

各種分布式系統(tǒng)平臺背景及開發(fā)中的應(yīng)用

5RJg_mcuworld ? 來源:互聯(lián)網(wǎng) ? 作者:佚名 ? 2018-04-08 08:49 ? 次閱讀

一、分布式架構(gòu)

架構(gòu)分布式的英文(Distributed computing分布式計算技術(shù))的應(yīng)用和工具,成熟目前的技術(shù)包括 J2EE,CORBA 和 .NET(DCOM),這些技術(shù)牽扯的內(nèi)容非常廣,相關(guān)的書籍也非常多。

本文不介紹這些技術(shù)的內(nèi)容,也沒有涉及這些技術(shù)的細節(jié),只是從各種分布式系統(tǒng)平臺產(chǎn)生的背景和在軟件開發(fā)中應(yīng)用的情況來探討它們的主要異同。

分布式系統(tǒng)是一個古老而寬泛的話題,而近幾年因為“大數(shù)據(jù)”概念的興起,又煥發(fā)出了新的青春與活力。

除此之外,分布式系統(tǒng)也是一門理論模型與工程技法。并重的學(xué)科內(nèi)容相比于機器學(xué)習(xí)這樣的研究方向,學(xué)習(xí)分布式系統(tǒng)的同學(xué)往往會感覺:“入門容易,深入難”的確,學(xué)習(xí)分布式系統(tǒng)幾乎不需要太多數(shù)學(xué)知識。

分布式系統(tǒng)是一個復(fù)雜且寬泛的研究領(lǐng)域,學(xué)習(xí)一兩門在線課程,看一兩本書可能都是不能完全覆蓋其所有內(nèi)容的。

總的來說,分布式系統(tǒng)要做的任務(wù)就是把多臺機器有機的組合,連接起來,讓其協(xié)同完成一件任務(wù),可以是計算任務(wù),也可以是存儲任務(wù)。

如果一定要給近些年的分布式系統(tǒng)研究做一個分類的話,我個人認為大概可以包括三大部分:

1. 分布式存儲系統(tǒng)

2. 分布式計算系統(tǒng)

3. 分布式管理系統(tǒng)

二、微服務(wù)

當(dāng)前微服務(wù)很熱,大家都號稱在使用微服務(wù)架構(gòu),但究竟什么是微服務(wù)架構(gòu)?微服務(wù)架構(gòu)是不是發(fā)展趨勢?對于這些問題,我們都缺乏清楚的認識。

為解決單體架構(gòu)下的各種問題,微服務(wù)架構(gòu)應(yīng)運而生。與其構(gòu)建一個臃腫龐大,難以馴服的怪獸,還不如及早將服務(wù)拆分。微服務(wù)的核心思想便是服務(wù)拆分與解耦,降低復(fù)雜性。

微服務(wù)強調(diào)將功能合理拆解,盡可能保證每個服務(wù)的功能單一,按照單一責(zé)任原則(Single Responsibility Principle)明確角色。將各個服務(wù)做輕,從而做到靈活,可復(fù)用,亦可根據(jù)各個服務(wù)自身資源需求,單獨布署,單獨作橫向擴展。

微服務(wù)架構(gòu)(Microservice Architecture)是一種架構(gòu)概念,旨在通過將功能分解到各個離散的服務(wù)中以實現(xiàn)對解決方案的解耦。你可以將其看作是在架構(gòu)層次而非獲取服務(wù)的

類上應(yīng)用很多 SOLID 原則。微服務(wù)架構(gòu)是個很有趣的概念,它的主要作用是將功能分解到離散的各個服務(wù)當(dāng)中,從而降低系統(tǒng)的耦合性,并提供更加靈活的服務(wù)支持。

概念:把一個大型的單個應(yīng)用程序和服務(wù)拆分為數(shù)個甚至數(shù)十個的支持微服務(wù),它可擴展單個組件而不是整個的應(yīng)用程序堆棧,從而滿足服務(wù)等級協(xié)議。

定義:圍繞業(yè)務(wù)領(lǐng)域組件來創(chuàng)建應(yīng)用,這些應(yīng)用可獨立地進行開發(fā),管理和迭代在分散的組件中使用云架構(gòu)和平臺式部署,管理和服務(wù)功能,使產(chǎn)品交付變得更加簡單。

本質(zhì):用一些功能比較明確,業(yè)務(wù)比較精練的服務(wù)去解決更大,更實際的問題。

三、源碼分析

從字面意義上來講,源文件的英文指一個文件,指源代碼的集合。源代碼則是一組具有特定意義的可以實現(xiàn)特定功能的字符(程序開發(fā)代碼)。

源碼分析是一種臨界知識,掌握了這種臨界知識,能不變應(yīng)萬變,源碼分析對于很多人來說很枯燥,生澀難懂。

源碼閱讀,我覺得最核心有三點:技術(shù)基礎(chǔ)+強烈的求知欲+耐心。

我認為是閱讀源碼的最核心驅(qū)動力我見到絕大多數(shù)程序員,對學(xué)習(xí)的態(tài)度,基本上就是這幾個層次(很偏激哦):

1,只關(guān)注項目本身,不懂就百度一下。

2,除了做好項目,還會閱讀和項目有關(guān)的技術(shù)書籍,看維基百科。

3,除了閱讀和項目相關(guān)的書外,還會閱讀IT行業(yè)的書,比如學(xué)的Java的時,還會去了解函數(shù)語言,如LISP。

4,找一些開源項目看看,大量試用第三方框架,還會寫寫演示。

5,閱讀基礎(chǔ)框架,J2EE 規(guī)范,調(diào)試服務(wù)器內(nèi)核。

大多數(shù)程序都是第1種,到第5種不光需要濃厚的興趣,還需要勇氣:?我能讀懂嗎其實,你能夠讀懂的

耐心,真的很重要。因為你極少看到閱讀源碼的指導(dǎo)性文章或書籍,也沒有人要求或建議你讀。

你讀的過程中經(jīng)常會卡住,而一卡主可能就陷進了迷宮這時,你需要做的,可能是暫時中斷一下,再從外圍看看它:如API結(jié)構(gòu),框架的設(shè)計圖。

四、工具使用

工欲善其事必先利其器,工具對 Java 的的程序員的重要性不言而喻現(xiàn)在有很多庫,實用工具和程序任的 Java 的開發(fā)人員選擇。下圖列出的工具都是程序員必不可少的工具

五、性能優(yōu)化

不管是應(yīng)付前端面試還是改進產(chǎn)品體驗,性能優(yōu)化都是躲不開的話題。

優(yōu)化的目的是讓用戶有“快”的感受,那如何讓用戶感受到快呢?

  • 加載速度真的很快,用戶打開輸入網(wǎng)址按下回車立即看到了頁面

  • 加載速度并沒有變快,但用戶感覺你的網(wǎng)站很快

性能優(yōu)化取決于多個因素,包括垃圾收集,虛擬機和底層操作系統(tǒng)(OS)設(shè)置。有多個工具可供開發(fā)人員進行分析和優(yōu)化時使用,你可以通過閱讀爪哇工具的源代碼優(yōu)化和分析來學(xué)習(xí)和使用它們。

必須要明白的是,沒有兩個應(yīng)用程序可以使用相同的優(yōu)化方式,也沒有完美的優(yōu)化的 Java 應(yīng)用程序的參考路徑。

使用最佳實踐并且堅持采用適當(dāng)?shù)姆绞教幚硇阅軆?yōu)化。想要達到真正最高的性能優(yōu)化,你作為一個 Java 的開發(fā)人員,需要對 Java 的虛擬機(JVM)和底層操作系統(tǒng)有正確的理解。

性能優(yōu)化,簡而言之,就是在不影響系統(tǒng)運行正確性的前提下,使之運行地更快,完成特定功能所需的時間更短。性能問題永遠是永恒的主題之一,而優(yōu)化則更需要技巧。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 虛擬機
    +關(guān)注

    關(guān)注

    1

    文章

    919

    瀏覽量

    28325
  • 分布式系統(tǒng)
    +關(guān)注

    關(guān)注

    0

    文章

    146

    瀏覽量

    19280

原文標題:十年開發(fā)經(jīng)驗總結(jié)的 Java 程序員架構(gòu)學(xué)習(xí)路線

文章出處:【微信號:mcuworld,微信公眾號:嵌入式資訊精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    分布式軟件系統(tǒng)

    、它可以解決組織機構(gòu)分散而數(shù)據(jù)需要相互聯(lián)系的問題。比如銀行系統(tǒng),總行與各分行處于不同的城市或城市的各個地區(qū),在業(yè)務(wù)上它們需要處理各自的數(shù)據(jù),也需要彼此之間的交換和處理,這就需要分布式系統(tǒng)
    發(fā)表于 07-22 14:53

    分布式控制系統(tǒng)

    、直接數(shù)字控制、人機交互以及監(jiān)控和管理等功能。分布式控制系統(tǒng)是在計算機監(jiān)督控制系統(tǒng)、直接數(shù)字控制系統(tǒng)和計算機多級控制系統(tǒng)的基礎(chǔ)上發(fā)展起來的,是生產(chǎn)過程的一種比較完善的控制與管理
    發(fā)表于 03-01 22:19

    如何設(shè)計分布式干擾系統(tǒng)?

    什么是分布式干擾系統(tǒng)?分布式干擾系統(tǒng)是一種綜合化、一體化、小型化、網(wǎng)絡(luò)化和智能化系統(tǒng),是將眾多體積小,重量輕,廉價的小功率偵察干擾機裝置在易
    發(fā)表于 08-08 06:57

    分布式系統(tǒng)的優(yōu)勢是什么?

    當(dāng)討論分布式系統(tǒng)時,我們面臨許多以下這些形容詞所描述的 同類型: 分布式的、刪絡(luò)的、并行的、并發(fā)的和分散的。分布式處理是一個相對較新的領(lǐng)域,所以還沒有‘致的定義。與順序計算相比、并行的
    發(fā)表于 03-31 09:01

    HarmonyOS應(yīng)用開發(fā)-分布式任務(wù)調(diào)度

    1. 介紹本篇CodeLab將實現(xiàn)的內(nèi)容HarmonyOS是面向全場景多終端的分布式操作系統(tǒng),使得應(yīng)用程序的開發(fā)打破了智能終端互通的性能和數(shù)據(jù)壁壘,業(yè)務(wù)邏輯原子化開發(fā),適配多端。通過一
    發(fā)表于 09-18 09:21

    HarmonyOS應(yīng)用開發(fā)-分布式設(shè)計

    設(shè)計理念HarmonyOS 是面向未來全場景智慧生活方式的分布式操作系統(tǒng)。對消費者而言,HarmonyOS 將生活場景的各類終端進行能力整合,形成“One Super Device”,以實現(xiàn)
    發(fā)表于 09-22 17:11

    如何實現(xiàn)校園分布式網(wǎng)絡(luò)測量系統(tǒng)的應(yīng)用設(shè)計?

    本文所述測量系統(tǒng)主要是基于校園網(wǎng)絡(luò),實現(xiàn)一個具有分布式、可擴展性的網(wǎng)絡(luò)測量平臺。利用各種測量方法和測量工具,測量校園網(wǎng)訪問公網(wǎng)和其他校園網(wǎng)絡(luò)各種
    發(fā)表于 05-06 08:48

    各種分布式電源的電氣特性

    PS:滲透率的概念:從字面上理解,“滲透”就是由分布式電源發(fā)出的功率進入(滲入)到配電系統(tǒng),所謂的“率”就是由分布式電源發(fā)出的電和整個系統(tǒng)所消耗的電(或者說總發(fā)電量)的一個比值。
    發(fā)表于 07-12 07:54

    如何高效完成HarmonyOS分布式應(yīng)用測試?

    作者:liuxun,HarmonyOS測試架構(gòu)師HarmonyOS是新一代的智能終端操作系統(tǒng),給開發(fā)者提供了設(shè)備發(fā)現(xiàn)、設(shè)備連接、跨設(shè)備調(diào)用等豐富的分布式API。隨著越來越多的開發(fā)者投入
    發(fā)表于 12-13 18:07

    分布式操作系統(tǒng)的相關(guān)資料分享

    文章目錄分布式操作系統(tǒng)嵌入操作系統(tǒng)集群操作系統(tǒng)集群系統(tǒng)管理
    發(fā)表于 12-22 07:23

    HarmonyOS應(yīng)用開發(fā)-EducationSystem分布式親子早教系統(tǒng)體驗

    一、說明遠程教育和多屏幕協(xié)作是智能教育的重要場景。 ? 本CodeLab使用親子早期教育系統(tǒng)來完成有關(guān)分布式早期教育算術(shù)問題和分布式益智游戲的綜合案例。 ? 它旨在幫助開發(fā)人員快速了解
    發(fā)表于 07-25 10:23

    分布式系統(tǒng)硬件資源池原理和接入實踐

    提供更好的服務(wù)體驗。 圖 3 鴻蒙硬件資源池支持各類消費者場景 2.2 開發(fā)者場景 對于開發(fā)者來說,由于分布式硬件資源池將跨設(shè)備硬件調(diào)用的復(fù)雜度都封裝在了系統(tǒng)底層,跨設(shè)備硬件復(fù)用本地
    發(fā)表于 12-06 10:02

    Windows平臺分布式實時仿真系統(tǒng)

    Windows平臺分布式實時仿真系統(tǒng)
    發(fā)表于 10-31 09:20 ?10次下載
    Windows<b class='flag-5'>平臺</b>的<b class='flag-5'>分布式</b>實時仿真<b class='flag-5'>系統(tǒng)</b>

    分布式數(shù)據(jù)對象的產(chǎn)生背景、原理及開發(fā)案例

    在3月底發(fā)布的OpenHarmony v3.1 Release版本,新增了分布式數(shù)據(jù)對象特性。什么是分布式數(shù)據(jù)對象呢?本期就讓我們一起來了解一下。
    的頭像 發(fā)表于 04-27 15:01 ?1246次閱讀
    <b class='flag-5'>分布式</b>數(shù)據(jù)對象的產(chǎn)生<b class='flag-5'>背景</b>、原理及<b class='flag-5'>開發(fā)</b>案例

    如何才能同步分布式系統(tǒng)的所有時鐘?

    分布式系統(tǒng)由Tanenbaum定義,“分布式系統(tǒng)是一組獨立的計算機,在”分布式系統(tǒng)?—?原理和范
    的頭像 發(fā)表于 02-06 11:00 ?1342次閱讀