springcloud 相同服務名_淺談分布式與微服務

? ? ?分布式和微服務是什么關系?簡單來說,分布式和微服務的概念比較相似,分布式屬于微服務。但是分布式和微服務在架構、作用和粒度上有所區別。因此,兩者的關系是既相互聯系又相互區別。本文主要帶大家認識分布式和微服務,并探討一下兩者的關系,感興趣的小伙伴可以接著看下去。

bbfa37aa072180fde5e8bf5792ae066e.png

微服務

? ? ? 微服務的意思也就是將模塊拆分成一個獨立的服務單元通過接口來實現數據的交互。簡單來說微服務就是很小的服務,小到一個服務只對應一個單一的功能,只做一件事。這個服務可以單獨部署運行,服務之間可以通過RPC來相互交互,每個微服務都是由獨立的小團隊開發,測試,部署,上線,負責它的整個生命周期。

分布式

? ? ? 分布式服務顧名思義服務是分散部署在不同的機器上的,一個服務可能負責幾個功能,是一種面向SOA架構的,服務之間也是通過rpc來交互或者是webservice來交互的。邏輯架構設計完后就該做物理架構設計,系統應用部署在超過一臺服務器或虛擬機上,且各分開部署的部分彼此通過各種通訊協議交互信息,就可算作分布式部署,生產環境下的微服務肯定是分布式部署的,分布式部署的應用不一定是微服務架構的,比如集群部署,它是把相同應用復制到不同服務器上,但是邏輯功能上還是單體應用。

關? 系

? ? ? 聯系:分布式只是一種手段,把不同的機器分散在不同的地方,然后這些機器間相互協助完成業務。微服務是一種特殊的分布式,換句話說,微服務架構是分布式服務架構的子集。微服務架構通過更細粒度的服務切分,使得整個系統的迭代速度并行程度更高,但是運維的復雜度和性能會隨著服務的粒度更細而增加。微服務重在解耦合,使每個模塊都獨立。分布式重在資源共享與加快計算機計算速度。

區? 別

(1)架構不同:微服務的設計是為了不因為某個模塊的升級和BUG影響現有的系統業務。微服務與分布式的細微差別是,微服務的應用不一定是分散在多個服務器上,他也可以是同一個服務器。

(2)作用不同:分布式:不同模塊部署在不同服務器上,分布式主要解決的是網站高并發帶來問題。微服務:各服務可獨立應用,組合服務也可系統應用。

(3)粒度不同:微服務相比分布式服務來說,它的粒度更小,服務之間耦合度更低,由于每個微服務都由獨立的小團隊負責,因此它敏捷性更高,分布式服務最后都會向微服務架構演化,這是一種趨勢,不過服務微服務化后帶來的挑戰也是顯而易見的,例如服務粒度小,數量大,后期運維將會很難。

SpringCloud和Dubbo

  • SpringCloud和Dubbo都是現在主流的微服務架構,SpringCloud是Apache旗下的Spring體系下的微服務解決方案,Dubbo是阿里系的分布式服務治理框架

  • 從技術維度上,其實SpringCloud遠遠的超過Dubbo,Dubbo本身只是實現了服務治理。dubbo就像組裝機,springcloud就像品牌一體機,更加強大,它是微服務架構下的一站式解決方案

  • 服務的調用方式Dubbo使用的是RPC遠程調用,而SpringCloud使用的是 Rest API,其實更符合微服務官方的定義

  • 服務網關,Dubbo并沒有本身的實現,只能通過其他第三方技術的整合,而SpringCloud有Zuul路由網關

  • 作為路由服務器,進行消費者的請求分發,SpringCloud還支持斷路器,與git完美集成分布式配置文件支持版本控制,事務總線實現配置文件的更新與服務自動裝配等等一系列的微服務架構要素

Rest和RPC對比

? ? ? 其實如果仔細閱讀過微服務提出者馬丁福勒的論文的話可以發現其定義的服務間通信機制就是Http Rest。RPC最主要的缺陷就是服務提供方和調用方式之間依賴太強,我們需要為每一個微服務進行接口的定義,并通過持續繼承發布,需要嚴格的版本控制才不會出現服務提供和調用之間因為版本不同而產生的沖突。REST是輕量級的接口,服務的提供和調用不存在代碼之間的耦合,只是通過一個約定進行規范,但也有可能出現文檔和接口不一致而導致的服務集成問題,但可以通過swagger工具整合,是代碼和文檔一體化解決,所以REST在分布式環境下比RPC更加靈活。

SpringBoot和SpringCloud

? ? ? SpringBoot是Spring推出用于解決傳統框架配置文件冗余,裝配組件繁雜的基于Maven的解決方案,旨在快速搭建單個微服務,而SpringCloud專注于解決各個微服務之間的協調與配置,服務之間的通信,熔斷,負載均衡等;技術維度并相同,并且SpringCloud是依賴于SpringBoot的,而SpringBoot并不是依賴與SpringCloud,甚至還可以和Dubbo進行優秀的整合開發。

  • SpringBoot專注于快速方便的開發單個個體的微服務

  • SpringCloud是關注全局的微服務協調整理治理框架,整合并管理各個微服務,為各個微服務之間提供,配置管理,服務發現,斷路器,路由,事件總線等集成服務

  • SpringBoot不依賴于SpringCloud,SpringCloud依賴于SpringBoot,屬于依賴關系

  • SpringBoot專注于快速,方便的開發單個的微服務個體,SpringCloud關注全局的服務治理框架

Eureka和ZooKeeper

????分布式系統中的三個重要特性:

  • 一致性(Consistency)

  • 可用性(Availability)

  • 分區容錯性(Tolerance of network Partition)

? ? ? CAP原理是指這三個要素最多只能同時實現兩點,不可能三者兼顧。因此在進行分布式架構設計時,必須做出取舍。而對于分布式數據系統,分區容忍性是基本要求,否則就失去了價值。因此設計分布式數據系統,就是在一致性和可用性之間取一個平衡。對于大多數WEB應用,其實并不需要強一致性,因此犧牲一致性而換取高可用性,是多數分布式數據庫產品的方向。

ZooKeeper保證的是CP,Eureka保證的是AP,ZooKeeper在選舉期間注冊服務癱瘓,雖然服務最終會恢復,但是選舉期間不可用的,Eureka各個節點是平等關系,只要有一臺Eureka就可以保證服務可用,而查詢到的數據并不是最新的。

自我保護機制會導致:

  • Eureka不再從注冊列表移除因長時間沒收到心跳而應該過期的服務

  • Eureka仍然能夠接受新服務的注冊和查詢請求,但是不會被同步到其他節點(高可用),當網絡穩定時,當前實例新的注冊信息會被同步到其他節點中(最終一致性)

  • Eureka可以很好的應對因網絡故障導致部分節點失去聯系的情況,而不會像ZooKeeper一樣使得整個注冊系統癱瘓

ZooKeeper有Leader和Follower角色,而Eureka各個節點平等;ZooKeeper采用過半數存活原則,Eureka采用自我保護機制解決分區問題;Eureka本質上是一個工程,而ZooKeeper只是一個進程。

???????eureka自我保護機制

? ? ? ?當Eureka Server 節點在短時間內丟失了過多實例的連接時(比如網絡故障或頻繁啟動關閉客戶端)節點會進入自我保護模式,保護注冊信息,不再刪除注冊數據,故障恢復時,自動退出自我保護模式。

GetMapping、PostMapping區別,PutMapping、DeleteMapping

  • @GetMapping用于將http?get請求映射到特定處理程序的方法注解,屬于組合注解,是@RequestMapping(method=RequestMethod.GET)的縮寫

  • 請求資源應該使用GET??

  • 添加資源應該使用POST??

  • 更新資源應該使用PUT??

  • 刪除資源應該使用DELETE

45fe6b97bf37175995d0c37f349077d3.png

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/529921.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/529921.shtml
英文地址,請注明出處:http://en.pswp.cn/news/529921.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

html div 子元素 過多 卡頓,CSS不定高元素transition動畫的解決方案

CSS不定高元素transition動畫的解決方案類別: 技術CSS時間:2019-07-27 23:41:35字數:3297版權所有,未經允許,請勿轉載,謝謝合作~### 前言CSS中transition可以方便的實現我們的過渡動畫效果,但并…

bat 變量 文件內容第一行_VBA基礎入門(38)FSO生成bat文件后執行的實例

1.首先,我們回顧下FSO是什么?文件系統對象FSO的英文全稱是File System Object ,這種對象模型提出了有別于傳統的文件操作語句處理文件和文件夾的方法。通過采用object.method這種在面向對象編程中廣泛使用的語法,將一系列操作文件…

HTML5廢除元素,HTML5 與 HTML4 的區別(2) - 新增的元素和廢除的元素

新增的結構元素在 HTML5 中,新增了以下與結構相關的元素:section元素section 元素表示頁面中的一個內容區塊,比如章節、頁眉、頁腳或頁面中的其他部分。它可以與h1、h2、h3、h4、h5、h6等元素結合起來使用,標識文檔結構。HTML5 中…

ps怎么更改背景圖層大小_PhotoShop處理圖層的一些技巧方法、PS圖層處理教程

一、了解圖層以及為什么它們如此有用。1.在“圖層”面板中查看和選擇圖層2.層包含組成分層文件的圖像,文本或對象。它們使您可以在一層上移動,編輯和使用內容,而不會影響其他層上的內容。3.圖層在“ 圖層”面板中按堆棧排列,該面板…

zabbix計算型監控項函數last_zabbix 自定義key類型之計算(Calculated items)-阿里云開發者社區...

計算類型的key定義主要是根據已定義過的key值來計算的。例如創建一個計算linux服務器內存實際使用大小的監控項(計算方法為:vm.memory.size[total]-vm.memory.size[cached]-vm.memory.size[free]),方法如下:1、在模板中或是主機中選擇監控項-…

使用計算機畫畫需要什么軟件,專業電腦繪畫用的是什么工具?

滿意答案srCDG3SL62013.11.13采納率:57% 等級:12已幫助:11125人電腦硬件配置(CPU,內存,顯卡等)越高,繪制大圖時,軟件不會卡。就會畫的很流暢。特別是Painter,模擬自然畫筆越真實,…

中如何移動物體在畫面中的位置_組合柜擺在客廳中什么位置最旺運?客廳中,財位是如何確定的?...

組合柜擺在客廳中什么位置最旺運?組合柜在風水中的重要性不如沙發,但要注意的宜忌事項也有很多。風水上講高者為山,低者為水,有高有低,有山有水,才符合風水原理。在客廳中,低的沙發是水&#xf…

計算機概論在線閱讀,計算器概論 or 計算機概論

計算機硬件的五大單元輸入單元、輸出單元、CPU內部控制單元、算數邏輯單元、主存儲器。中央處理器 CPU Central Processing UnitCPU 的種類精簡指令集 Reduced Instruction Set Computing, RISCSun SPARCIBM Power Architecture復雜指令集 Complex Instruction Set Comp…

螺旋天線有方向性嗎_螺旋天線方向圖

luoxuan13度.zip.zip我畫的二臂螺旋天線同軸電纜饋電,得到的方向圖是酒杯形狀的,而不是半球行的,修改了好多次參數都是這樣,這可如何是好,我的模型有問題么?還是哪里出了問題,請幫忙。怎么沒人幫…

jquery ajax html編碼,jQuery AJAX字符編碼

我目前正在編碼一個法語網站。有一個時間表頁面,可以使用側面的鏈接加載另一天的時間表。這是我用來執行此操作的JS:function load(y) {$.get(y,function(d) {$("#replace").html(d);mod();});}function mod() {$("#dates a").click…

miui10讀取不了u盤_u盤能識別但無法讀取_u盤無法識別如何修復

2019-08-07 14:04:57U盤設備大家都比較熟悉了,正常情況下,電腦插入U盤后會自動識別讀取數據,然后在打開U盤數據進行操作。但是有用戶反映將U盤插入win10系統后竟然無法識別,難道是U盤設備壞了,但是在...2018-06-07 10:…

四川大學計算機學院趙怡,【喜訊】我校計算機學院學子在藍橋杯大賽全國總決賽中再獲佳績...

在第十一屆藍橋杯“全國軟件和信息技術專業人才大賽”省賽上,我校選手面對包括北京大學、清華大學、上海交通大學、北京航空航天大學、武漢大學、西安交通大學、北京理工大學、四川大學、電子科技大學、吉林大學、東北大學等在內的1200余所高校,6萬余名頂…

2002勘察設計收費標準_上海裝修設計師的收費標準是什么?

目前家裝行業的發展趨勢全是特別迅速的,一點都不落后于房地產業的發展趨勢,因此目前在好多大城市全是各式各樣的家裝公司,這篇以上海裝修公司為例,向大伙兒詳細介紹一下上海裝修設計公司的有些收費標準,看一下絕大多數…

計算機控制系統EHA,優·計算機控制技術第四章.doc

第四章 過程控制理論與技術4.1 過程控制系統的連續化設計4.1.1 概述1.簡述計算機控制系統的設計,是指在給定系統性能指標的條件下,設計出控制器的控制規律和相應的數字控制算法。典型的計算機控制系統如圖4.1.1所示。系統的輸入r(t)跟系統的輸出y(t)比較…

華為暢享10s值得買嗎_華為暢享10 Plus值不值得買?首批購買用戶評價出爐

原標題:華為暢享10 Plus值不值得買?首批購買用戶評價出爐【手機中國新聞】9月5日,華為在西安召開華為暢享10 Plus新品發布會,擁有著天空之境等新潮配色的華為暢享10 Plus也正式和大家見面。這款產品不僅采用了升降式攝像頭設計&am…

計算機應用基礎二作業,計算機應用基礎(二)作業2 (精選可編輯)

《計算機應用基礎(二)作業2 (精選可編輯)》由會員分享,可在線閱讀,更多相關《計算機應用基礎(二)作業2 (精選可編輯)(15頁珍藏版)》請在金鋤頭文庫上搜索。1、題目01 在Windows 控制面板中,使用添加刪除程序的作用是_。a. 設置字體 b. 安裝未…

colab清理gpu緩存_安卓手機為什么會變卡?強制GPU渲染手機就能變流暢?你真的懂嗎...

使用過安卓手機的朋友都知道,安卓手機最大的毛病就是卡頓,那你知道安卓手機變卡的原因嗎?還有網上很多教程說開啟“強制進行GPU渲染”手機就會變流暢,真的是這樣嗎?我們先來了解安卓手機為什么會變卡:安卓手…

脈沖寬度調制pdm_STM32第七章-脈沖寬度調制

先說在開頭啊,我們學習定時器總感覺它是很難的,這里我就不說他的編程難度,而是對于它的理解難度。學習定時器你就必須了解他的來龍去脈。比如說你現在要使用一個定時器,那么先要決定你要用哪一個定時器,是高級定時器還…

浙大 計算機 畢業論文格式,浙大碩士畢業論文格式

浙大碩士畢業論文格式時間:2017-06-15 來源:未知 本文字數:2725字作者:胡老師 單位:寫畢業論文主要目的是培養學生綜合運用所學知識和技能,理論聯系實際,獨立分析,解決實際問題的能力…

蘋果13系統鎖屏延遲_iPhone11 鎖屏出現延遲,iOS13 新 Bug?

點擊 哎咆科技 關注我們這兩天很多人在后臺反應,用 iPhone11 鎖屏的時候出現了延遲的情況。雖然延遲并不是很長,但還是會有“卡頓”的感覺。咆哥:我最近也感覺到了。于是很多同學認為,是不是 iOS13 系統的問題?你們多慮…