小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

微服務架構入門教程

 蘭亭文藝 2019-06-18

微服務架構入門

1. 微服務簡介

微服務是一種架構風格,一個大型的復雜軟件由一個或多個微服務組成。系統(tǒng)中每個微服務都可以被獨立部署,各個微服務之間是松耦合的。每個微服務僅關注于完成一件任務并很好地完成任務。在所有情況下,每個任務代表這一個小的業(yè)務能力。

微服務的核心思想是:一個完整的應用由多個小的、相互獨立的微服務組成,這些微服務運行在自己的進程中,開發(fā)和發(fā)布都沒有依賴。不同微服務通過一些輕量級交互機制來通信,例如RPC、HTTP等,服務可獨立拓展伸縮,每個服務定義了明確的邊界,不同的服務甚至可以采用不同的編程語言來實現(xiàn),由獨立團隊維護。簡單的來說,一個系統(tǒng)的不同模塊轉變成不同的服務!而且服務可以使用不同的技術加以實現(xiàn)!

微服務的目的是為了根據(jù)業(yè)務有效拆分應用,實現(xiàn)敏捷開發(fā)和部署。

2. 微服務應用與整體式應用以及SOA的區(qū)別

2.1 與整體式(單體)應用的區(qū)別

微服務與整體式應用的主要差異在于組裝應用組件,微服務架構將相關聯(lián)的業(yè)務邏輯及數(shù)據(jù)放在一起形成獨立的邊界,其目的是在不影響其他應用組件(微服務)的情況下更快地交付并推出市場。

整體式應用 微服務應用
進程數(shù) 將所有功能放到同一個進程中
拓展方式 通過復制整個應用到多臺服務器實現(xiàn)拓展
快速響應變更 隨著云化以及應用功能變得越來越頻繁,整體式應用在快速響應市場上顯得越來越力不從心。部分更新,都需要重新部署整個應用
團隊結構 團隊結構呈現(xiàn)垂直化,每個團隊專門負責專門的一塊,比如分為:UI設計團隊、中間件團隊、業(yè)務開發(fā)團隊、數(shù)據(jù)庫管理團隊等。
可用性 一個服務的不穩(wěn)定可能導致整個應用出現(xiàn)問題
創(chuàng)新性 很難引入新的技術和框架,所有功能都使用的同一種框架

這里寫圖片描述

2.2 與SOA的區(qū)別

看了很多網(wǎng)上對微服務和SOA區(qū)別的看法,分為兩種,一種是對區(qū)別侃侃而談,列舉了很多,另一種認為微服務其實是SOA的一種架構實現(xiàn)。從中可以看出微服務和SOA還是有很多相似之處的,只是針對業(yè)務需求進行區(qū)別設計。

如果非要說區(qū)別的話,微服務架構與SOA最主要的區(qū)別在于:微服務不再強調傳統(tǒng)SOA架構里面比較重的ESB企業(yè)服務總線,同時SOA的思想進入到單個業(yè)務系統(tǒng)內部實現(xiàn)真正的組件化。

3. 微服務架構的一些特性

1. 通過服務實現(xiàn)應用的組件化

微服務架構中將組件定義為可被獨立代替和升級的軟件單元,在應用架構設計中通過正整體應用切分成可獨立部署升級的微服務方式進行組件化設計。

2.圍繞業(yè)務能力組織服務

以業(yè)務能力為出發(fā)點組織服務,微服務團隊的組織結構必須是跨功能的(比如:即管應用也管數(shù)據(jù)庫),通常團隊功能不會太大。

3. 產(chǎn)品而非項目模式

傳統(tǒng)的應用模式是一個團隊以項目模式開發(fā)完整的應用,開發(fā)完成后就交付給運維團隊負責維護,微服務架構則倡導一個團隊應該負責一個“微服務”完整的生命周期,“誰開發(fā),誰負責”。

4. 智能端點和管道扁平化

微服務架構主張將組件通訊的相關業(yè)務邏輯/智能放在組件端點側而非放在通訊組件中,通訊機制或組件應該盡量簡單及松耦合。

5. “去中心化”治理

整體式應用往往傾向于采取單一技術平臺,微服務架構則鼓勵使用合適的工具完成各自的任務,每個微服務可以考慮選用最佳工具完成,如不同的編程語言。

6. “去中心化”數(shù)據(jù)管理

微服務架構倡導采用多樣性持久化的方法,讓每個微服務管理其自由數(shù)據(jù)庫,并允許不同微服務采用不同的數(shù)據(jù)持久化技術。

7. 基礎設施自動化

云化及自動化部署等技術極大地降低了微服務構建、部署和運維的難度,通過應用持續(xù)集成和持續(xù)交付等方法有助于達到加速推出市場的目的。

8. 故障處理設計

微服務架構所帶來的一個后果就是必須考慮每個服務的失敗容錯機制。因此,微服務非常重視建立架構及相關業(yè)務指標的實時監(jiān)控和日志機制。

9. 演進式的設計

微服務應用更注重快速更新,因此系統(tǒng)會隨時間不斷演進。微服務的設計受業(yè)務功能的生命周期等因素影響。如某應用是整體式應用,但逐漸朝微服務應用架構演進,整體式應用仍是核心,但新功能將使用所提供的API構建。再如在某微服務應用中,可代替模塊設計的基本原則,在實施后發(fā)現(xiàn)某兩個微服務經(jīng)常必須同時更新,則這可能意味著應將其合并為一個服務。

4. 微服務的優(yōu)缺點

優(yōu)點:

每個服務都比較簡單,可以提供更高的靈活性; 微服務架構的方式是松耦合的,可以提供更高的靈活性; 微服務可通過最佳及合適的不同開發(fā)語言與工具(比如不同的數(shù)據(jù)庫)進行開發(fā),能夠做到有的放矢地解決針對性問題; 每個微服務可由不同團隊獨立開發(fā),互不影響,加快推出市場的速度; 微服務架構是持續(xù)交付的巨大動力,允許在頻繁發(fā)布不同服務的同時保持系統(tǒng)其它部分的可用性和穩(wěn)定性。

缺點:

微服務的想法在實踐上是好的,單當整體實現(xiàn)時也會呈現(xiàn)出復雜性。

運維開銷及成本增加:整體應用可能只需要部署至一小片應用服務區(qū)集群,而微服務可能變成需要構建/測試/部署/運行數(shù)十個獨立的服務,并可能需要支持多種語言和環(huán)境。這導致一個整體式系統(tǒng)如果由20個微服務組成,可能需要40-60個進程。 必須具有DevOps開發(fā)運維一體化技能:開發(fā)人員需要熟知運維與投產(chǎn)環(huán)境,開發(fā)人員也需要掌握必要的數(shù)據(jù)存儲技術如NoSQL,具有較強DevOps技能的人員比較稀缺。 隱式接口與接口匹配問題:把系統(tǒng)分為多個協(xié)作組件后會產(chǎn)生新的接口,這意味著簡單的交叉變化可能需要改變許多組件,并需要協(xié)調一起發(fā)布。在實際環(huán)境中,一個新品發(fā)布可能被迫同時發(fā)布大量服務,由于集成點的大量增加,微服務架構會有更高的發(fā)布風險。 代碼重復:某些底層功能需要被多個服務所用,為了避免將”同步耦合引入到系統(tǒng)中“,有時候需要向不同服務添加同樣的代碼,這就會導致代碼重復。 分布式系統(tǒng)的復雜性:作為一種分布式系統(tǒng),微服務引入了復雜性和其他若干問題,例如網(wǎng)絡延遲、容錯性、消息序列化、不可靠的網(wǎng)絡、異步機制、版本化、差異化的工作負載等,開發(fā)人員需要考慮以上的分布式系統(tǒng)問題。 異步機制:微服務往往使用異步編程、消息并行機制,如果應用存在跨微服務的事務性處理,其實現(xiàn)機制會變得復雜化。 可測性的挑戰(zhàn):在動態(tài)環(huán)境下服務間的交互會產(chǎn)生非常微妙的行為,難以可視化及全面測試。經(jīng)典微服務往往不太重視測試,更多的是通過監(jiān)控發(fā)現(xiàn)生產(chǎn)環(huán)境的異常,進而快速回滾或采取必要的其他行動,但對于特別在意風險規(guī)避監(jiān)管或投產(chǎn)環(huán)境錯誤會產(chǎn)生顯著影響的場景下需要特別注意。 部署復雜:一個單體應用只需要在復雜均衡器后面部署各自的服務器就好了。每個應用實例是需要配置諸如數(shù)據(jù)庫和消息中間件等基礎服務。相比之下,一個微服務應用一般由大批服務構成,這就形成大量需要配置、部署、擴展和監(jiān)控的部分。除此之外,你還需要完成一個服務發(fā)現(xiàn)機制,以用來發(fā)現(xiàn)與它通訊服務的地址(包括服務器地址和端口)。

5. 微服務的取舍

在合適的項目,合適的團隊,采用微服務架構收益會大于成本。 微服務架構有很多吸引人的地方,但在擁抱微服務之前,也需要認清它所帶來的挑戰(zhàn)。 需要避免為了“微服務”而“微服務”。 微服務架構引入策略 – 對傳統(tǒng)企業(yè)而言,開始時可以考慮引入部分合適的微服務架構原則對已有系統(tǒng)進行改造或新建微服務應用,逐步探索及積累微服務架構經(jīng)驗,而非全盤實施微服務架構。

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多