日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

如何看待微软新开源的Service Fabric?

發(fā)布時(shí)間:2023/12/4 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何看待微软新开源的Service Fabric? 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

本人曾在Service Fabric (SF)項(xiàng)目中做了幾年,這次很興奮能看到它的開源。短短兩天已經(jīng)有1300多個(gè)關(guān)注了。我看了一下開源的代碼,真是滿滿的干貨,200多萬(wàn)行C++代碼,所有最核心的協(xié)議算法都在里面。但是,不得不承認(rèn),現(xiàn)在各種微服務(wù)框架已經(jīng)用的非常廣泛,Service Fabric出來(lái)的晚,對(duì)它的定位會(huì)十分尷尬。而且官方的文檔寫的大而全,看了讓人更糊涂。我這里根據(jù)自己的理解解釋一下。

SF定位是一個(gè)“分布式系統(tǒng)平臺(tái)”,意思就是說(shuō),它是用來(lái)寫其他的分布式系統(tǒng)的,比如有了SF,就可以很容易寫個(gè)Zookeeper、分布式Redis或者分布式數(shù)據(jù)庫(kù)。但各種應(yīng)用千差萬(wàn)別,怎么能實(shí)現(xiàn)一個(gè)你自己的分布式XYZ呢?SF通過主打有狀態(tài)服務(wù)(Stateful Service)來(lái)幫你實(shí)現(xiàn)這個(gè)目的。

先從無(wú)狀態(tài)服務(wù)(Stateless Service)說(shuō)起,這個(gè)是目前大多數(shù)應(yīng)用采用的方式。比如這個(gè)圖是一個(gè)很典型的三層結(jié)構(gòu):前端,中間層和存儲(chǔ)層,此外通常還會(huì)加個(gè)緩存層。前端和中間層都是無(wú)狀態(tài)的,就是說(shuō)其中不保存數(shù)據(jù),可以比較容易地增加或減少節(jié)點(diǎn)。存儲(chǔ)層是有狀態(tài)的,需要特別留意數(shù)據(jù)安全性和一致性。由于前端過來(lái)的請(qǐng)求可能由于網(wǎng)絡(luò)或者硬件故障而丟失,就需要使用隊(duì)列來(lái)增強(qiáng)可靠性。如果訪問數(shù)據(jù)速度是瓶頸,還需要增加緩存層,緩存層也是有狀態(tài)的,所以緩存本身以及緩存和存儲(chǔ)層的數(shù)據(jù)一致性也需要很小心。


<img src="https://pic1.zhimg.com/50/v2-796dfde978007dda05603f591b0baf4c_hd.jpg" data-caption="" data-size="normal" data-rawwidth="1020" data-rawheight="601" class="origin_image zh-lightbox-thumb" width="1020" data-original="https://pic1.zhimg.com/v2-796dfde978007dda05603f591b0baf4c_r.jpg">


有狀態(tài)服務(wù)(Stateful Service)采用另一種思路,把數(shù)據(jù)與處理它的程序部署在一起,如下圖里面,把存儲(chǔ)層的數(shù)據(jù)進(jìn)行分片后移到中間層,每片數(shù)據(jù)對(duì)應(yīng)自己的一套處理程序。每片數(shù)據(jù)有奇數(shù)個(gè)副本,由SF來(lái)保證這些副本之間的數(shù)據(jù)的可靠性和一致性。好處就是,首先數(shù)據(jù)處理程序只需要關(guān)心本地?cái)?shù)據(jù),邏輯大大簡(jiǎn)化;其次數(shù)據(jù)的傳輸變少了,性能可以得到很大改善;而且系統(tǒng)架構(gòu)變簡(jiǎn)單了,不需要在存儲(chǔ)層、緩存層、隊(duì)列等地方分別管理可靠性和一致性,只在SF一個(gè)地方管理。


<img src="https://pic2.zhimg.com/50/v2-f6df2d79d70d29d1234045cefb13a565_hd.jpg" data-caption="" data-size="normal" data-rawwidth="989" data-rawheight="598" class="origin_image zh-lightbox-thumb" width="989" data-original="https://pic2.zhimg.com/v2-f6df2d79d70d29d1234045cefb13a565_r.jpg">



為了保證數(shù)據(jù)一致性和可靠性,SF設(shè)計(jì)了非常復(fù)雜的協(xié)議,比如數(shù)據(jù)修改操作怎么同步到多個(gè)副本,數(shù)據(jù)修改如何保證嚴(yán)格有序,主副本如果失效該如何選舉下一個(gè)主副本,節(jié)點(diǎn)如何動(dòng)態(tài)加入和去除,容器的負(fù)載(內(nèi)存+CPU)過大如何進(jìn)行均衡等等。這些協(xié)議是我們當(dāng)時(shí)花最多精力的,因?yàn)橐С诸愃品植际綌?shù)據(jù)庫(kù)這樣的應(yīng)用,要從理論上保證它的正確性,不能有一點(diǎn)意外。


相關(guān)文章:?

  • 重磅消息-Service Fabric 正式開源

原文地址:https://www.zhihu.com/question/268819708/answer/343732457


.NET社區(qū)新聞,深度好文,歡迎訪問公眾號(hào)文章匯總 http://www.csharpkit.com


總結(jié)

以上是生活随笔為你收集整理的如何看待微软新开源的Service Fabric?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。