日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁(yè) > 科技  > 軟件

「Go面經(jīng)」算法 并發(fā)模型 緩存落盤 etcd actor模型

來(lái)源: 責(zé)編: 時(shí)間:2023-08-14 22:01:51 12791觀看
導(dǎo)讀Hello,大家好,我是陽(yáng)哥。失蹤人口回歸,最近太忙,好久沒(méi)有更文啦。本文先分享2段面經(jīng),文末總結(jié)了關(guān)鍵問(wèn)題的復(fù)盤筆記。一定要看到最后!求職者情況分享一下好友的最新面經(jīng)。簡(jiǎn)單說(shuō)下這位好友的情況:坐標(biāo)成都,游戲行業(yè),3年開(kāi)發(fā)經(jīng)

Hello,大家好,我是陽(yáng)哥。失蹤人口回歸,最近太忙,好久沒(méi)有更文啦。i2128資訊網(wǎng)——每日最新資訊28at.com

本文先分享2段面經(jīng),文末總結(jié)了關(guān)鍵問(wèn)題的復(fù)盤筆記。一定要看到最后!i2128資訊網(wǎng)——每日最新資訊28at.com

求職者情況

分享一下好友的最新面經(jīng)。i2128資訊網(wǎng)——每日最新資訊28at.com

簡(jiǎn)單說(shuō)下這位好友的情況:坐標(biāo)成都,游戲行業(yè),3年開(kāi)發(fā)經(jīng)驗(yàn),最近2年做Go語(yǔ)言開(kāi)發(fā),1年Java/PHP工作經(jīng)驗(yàn)。i2128資訊網(wǎng)——每日最新資訊28at.com

手撕CSAPP選手,半年前堅(jiān)持打卡手寫的學(xué)習(xí)筆記。(最近半年被公司摧殘,沒(méi)時(shí)間了....)i2128資訊網(wǎng)——每日最新資訊28at.com

面經(jīng)分享

第一家

Golang后端,3年+經(jīng)驗(yàn),游戲行業(yè),成都,15~25Ki2128資訊網(wǎng)——每日最新資訊28at.com

下面以對(duì)話的方式大概描述問(wèn)題:i2128資訊網(wǎng)——每日最新資訊28at.com

A--->面試官i2128資訊網(wǎng)——每日最新資訊28at.com

B--->我i2128資訊網(wǎng)——每日最新資訊28at.com

A:自我介紹i2128資訊網(wǎng)——每日最新資訊28at.com

B:巴拉巴拉i2128資訊網(wǎng)——每日最新資訊28at.com

A:Actor 模型你是怎么理解的?i2128資訊網(wǎng)——每日最新資訊28at.com

B:無(wú)鎖的并發(fā)計(jì)算模型,Actor 有自己的狀態(tài),只能通過(guò) mailBox 去收發(fā)消息、異步消息傳遞~i2128資訊網(wǎng)——每日最新資訊28at.com

A:你不是百度了吧?i2128資訊網(wǎng)——每日最新資訊28at.com

B:沒(méi)有。因?yàn)槲矣X(jué)得它的一部分思想和 Go 的 GMP 挺像的,好記(這里我就給自己挖坑了,擦嘞~)i2128資訊網(wǎng)——每日最新資訊28at.com

A:你能說(shuō)說(shuō)它們哪里像嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:Go 的調(diào)度器全局隊(duì)列和它的 MailBox 挺像的i2128資訊網(wǎng)——每日最新資訊28at.com

A:那你的意思是,實(shí)現(xiàn) MailBox,你會(huì)使用隊(duì)列嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:是的,用 chan 關(guān)鍵字,元素類型為 Interfacei2128資訊網(wǎng)——每日最新資訊28at.com

A:這樣是可以,那么我給你一個(gè)場(chǎng)景,在同一時(shí)刻,有 1 萬(wàn)個(gè)消息打進(jìn)來(lái)呢?i2128資訊網(wǎng)——每日最新資訊28at.com

B:增加緩沖區(qū)大小、無(wú)鎖隊(duì)列、批量處理消息、背壓機(jī)制i2128資訊網(wǎng)——每日最新資訊28at.com

A:能從數(shù)據(jù)結(jié)構(gòu)的角度說(shuō)說(shuō)嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:chan 底層是數(shù)組,線性結(jié)構(gòu),我想用非線性結(jié)構(gòu)紅黑樹(shù)接收消息i2128資訊網(wǎng)——每日最新資訊28at.com

A:為什么?i2128資訊網(wǎng)——每日最新資訊28at.com

B:因?yàn)?epoll 模型就是這么做的i2128資訊網(wǎng)——每日最新資訊28at.com

A:優(yōu)勢(shì)是什么i2128資訊網(wǎng)——每日最新資訊28at.com

B:忘了...i2128資訊網(wǎng)——每日最新資訊28at.com

A:你再想想,比如動(dòng)態(tài)調(diào)整緩沖區(qū),可是是一瞬間打進(jìn)來(lái)的,你怎么知道調(diào)整的多大,預(yù)留也不好做,巴拉巴拉i2128資訊網(wǎng)——每日最新資訊28at.com

B:額,不知道i2128資訊網(wǎng)——每日最新資訊28at.com

A:用環(huán)形隊(duì)列i2128資訊網(wǎng)——每日最新資訊28at.com

B:啊?我沒(méi)想到,因?yàn)槲业挠∠罄铮奶囟ㄊ枪潭ù笮。⑻嗔耍皇菚?huì)覆蓋嗎,會(huì)導(dǎo)致消息丟失。(我提出這個(gè)疑問(wèn)的時(shí)候,他沒(méi)有繼續(xù)給我聊了,如果只用環(huán)形隊(duì)列肯定有這個(gè)問(wèn)題)我確實(shí)沒(méi)有想到,很少用到它...i2128資訊網(wǎng)——每日最新資訊28at.com

A:你能聊聊分布式嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:巴拉巴拉,有擴(kuò)展性、容錯(cuò)、很多節(jié)點(diǎn),不同地域、數(shù)據(jù)共享,巴拉巴拉i2128資訊網(wǎng)——每日最新資訊28at.com

A:你提到了數(shù)據(jù)共享,那你說(shuō)說(shuō)一致性你怎么做?i2128資訊網(wǎng)——每日最新資訊28at.com

B:我會(huì)先想到用 etcd 吧,因?yàn)樗?raft 可以保證一致性i2128資訊網(wǎng)——每日最新資訊28at.com

A:繼續(xù)...i2128資訊網(wǎng)——每日最新資訊28at.com

B:etcd Leader選舉、數(shù)據(jù)復(fù)制、心跳、然后讀取,保證一致性,巴拉巴拉它們的細(xì)節(jié)i2128資訊網(wǎng)——每日最新資訊28at.com

A:etcd 是鍵值數(shù)據(jù)庫(kù)呀,主要場(chǎng)景是配置之類的吧,那我現(xiàn)在有一個(gè)場(chǎng)景,就是 10w qps 如何承載 50w qps 的場(chǎng)景,同時(shí)保證它們的數(shù)據(jù)一致性i2128資訊網(wǎng)——每日最新資訊28at.com

B:啥?(我有點(diǎn)沒(méi)聽(tīng)懂這個(gè)問(wèn)題,硬來(lái))首先是能夠承載這個(gè)量級(jí)吧,考慮主從復(fù)制,然后用分片技術(shù)水平擴(kuò)展、異步處理、加緩存巴拉巴拉i2128資訊網(wǎng)——每日最新資訊28at.com

A:主從同步你能說(shuō)說(shuō)典型的應(yīng)用嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:(我已經(jīng)被前面那個(gè)問(wèn)題問(wèn)蒙蔽了,想說(shuō) Redis 的,有點(diǎn)開(kāi)不了口)額...i2128資訊網(wǎng)——每日最新資訊28at.com

A:Redis 就是主從吧!i2128資訊網(wǎng)——每日最新資訊28at.com

B:是....是的i2128資訊網(wǎng)——每日最新資訊28at.com

然后就下來(lái)就是 Redis 拷打小皮鞭了,不多說(shuō)了,謝謝大家。i2128資訊網(wǎng)——每日最新資訊28at.com

第二家

Golang后端,坐標(biāo)成都,游戲行業(yè),15~20ki2128資訊網(wǎng)——每日最新資訊28at.com

先說(shuō)感受,總體不是很難。下面聽(tīng)我慢慢聊:i2128資訊網(wǎng)——每日最新資訊28at.com

A -> 面試官i2128資訊網(wǎng)——每日最新資訊28at.com

B -> 我i2128資訊網(wǎng)——每日最新資訊28at.com

A:自我介紹i2128資訊網(wǎng)——每日最新資訊28at.com

B:巴拉巴拉i2128資訊網(wǎng)——每日最新資訊28at.com

A:我看你簡(jiǎn)歷上提到力扣做了挺多題的。i2128資訊網(wǎng)——每日最新資訊28at.com

B:是的,但是已經(jīng)有段時(shí)間沒(méi)做了,做過(guò)的題我都有基本思路。i2128資訊網(wǎng)——每日最新資訊28at.com

A:你能說(shuō)說(shuō)你知道哪些排序嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:冒泡、選擇、插入、快速、歸并、堆、桶i2128資訊網(wǎng)——每日最新資訊28at.com

A:快排你能說(shuō)一下它的思路嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:通過(guò)選擇一個(gè)基準(zhǔn)元素,將數(shù)組分割成左右兩個(gè)子數(shù)組,再對(duì)子數(shù)組進(jìn)行遞歸排序,直到整個(gè)數(shù)組有序。i2128資訊網(wǎng)——每日最新資訊28at.com

A:穩(wěn)定排序和不穩(wěn)定排序的概念能換說(shuō)一下嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:假如排序前后兩個(gè)元素的相對(duì)順序在排序后仍然不變,那么這種算法就是穩(wěn)定排序。不穩(wěn)定排序反之。(這里答的其實(shí)不太好,可以結(jié)合前面提到的排序算法說(shuō)一下,哪些具體的算法是穩(wěn)定的)i2128資訊網(wǎng)——每日最新資訊28at.com

A:你對(duì)二叉樹(shù)了解嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:了解的,樹(shù)形結(jié)構(gòu),有根節(jié)點(diǎn)、父節(jié)點(diǎn)、子節(jié)點(diǎn)、葉子節(jié)點(diǎn)、度、高度、深度這些概念。i2128資訊網(wǎng)——每日最新資訊28at.com

A:常見(jiàn)的二叉樹(shù)有哪些?i2128資訊網(wǎng)——每日最新資訊28at.com

B:平衡二叉樹(shù)、二叉搜索樹(shù),巴拉巴拉。i2128資訊網(wǎng)——每日最新資訊28at.com

A:能說(shuō)一下前序遍歷和后序遍歷嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:前序遍歷,遍歷順序是根節(jié)點(diǎn)、左子樹(shù)、右子樹(shù)。后序遍歷是左子樹(shù)、右子樹(shù)、根節(jié)點(diǎn)。i2128資訊網(wǎng)——每日最新資訊28at.com

A:前序遍歷和后續(xù)遍歷能夠構(gòu)建一顆二叉樹(shù)嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:額,這個(gè)問(wèn)題我不太理解。。。i2128資訊網(wǎng)——每日最新資訊28at.com

A:沒(méi)事,換一個(gè)問(wèn)題。Go 語(yǔ)言中的 Map 是如何實(shí)現(xiàn)的,你能聊一聊嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:Map 是使用哈希表、鏈表來(lái)實(shí)現(xiàn)的。然后我從散列函數(shù)、解決哈希沖突、動(dòng)態(tài)擴(kuò)容、并發(fā)安全性聊i2128資訊網(wǎng)——每日最新資訊28at.com

A:Go 的并發(fā)模式你了解嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:請(qǐng)問(wèn)是指的扇入扇出模式、for select 循環(huán)模式這種嗎?(后來(lái)回憶一下,面試官想讓我聊的應(yīng)該是CSP并發(fā)模型)i2128資訊網(wǎng)——每日最新資訊28at.com

A:不是,你可以說(shuō)一說(shuō)你了解的 Go 的并發(fā)原語(yǔ)i2128資訊網(wǎng)——每日最新資訊28at.com

B:好的,我從兩個(gè)部分簡(jiǎn)單說(shuō)一下,一個(gè)就是關(guān)鍵字,另一個(gè)是包。像關(guān)鍵字有 go,創(chuàng)建協(xié)程。channel,進(jìn)行通信。select,處理 channel 的收發(fā)。mutex,鎖。context,上下文。包的話 atomic。i2128資訊網(wǎng)——每日最新資訊28at.com

A:你知道 csp 嗎,能簡(jiǎn)單說(shuō)一下嘛?i2128資訊網(wǎng)——每日最新資訊28at.com

B:(我腦子里第一時(shí)間和 cap 搞混了,但還是拉回來(lái)了)csp 是一種通信協(xié)作模型。在 Go 里面有一句很經(jīng)典的話,不要用共享內(nèi)存來(lái)通信,要用通信來(lái)共享內(nèi)存。i2128資訊網(wǎng)——每日最新資訊28at.com

A:(露出了滿意的笑容,扭頭看向旁邊的同事)我沒(méi)什么問(wèn)的了,你有什么問(wèn)的嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

B:你之前用過(guò) mongodb,存儲(chǔ)在 mongodb 中的索引你是怎么設(shè)計(jì)的?i2128資訊網(wǎng)——每日最新資訊28at.com

A:不好意思,我之前沒(méi)有關(guān)注過(guò)這個(gè)部分,因?yàn)橹暗恼w架構(gòu)都是將需要落盤的數(shù)據(jù)放在內(nèi)存,然后標(biāo)記臟位,通過(guò)一些策略來(lái)異步落盤,而需要查詢數(shù)據(jù)時(shí),也是直接從內(nèi)存查詢,因?yàn)轫?xiàng)目啟動(dòng)時(shí),會(huì)把所有的玩家數(shù)據(jù)加載到內(nèi)存中。i2128資訊網(wǎng)——每日最新資訊28at.com

B:沒(méi)事,那我們聊一下 redis 吧,你知道 redis 的落盤方案嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

A:知道,AOF、RDB(然后開(kāi)始介紹它們的特點(diǎn))巴拉巴拉i2128資訊網(wǎng)——每日最新資訊28at.com

B:你會(huì)如何評(píng)估 redis 的落盤方案?i2128資訊網(wǎng)——每日最新資訊28at.com

A:我會(huì)從數(shù)據(jù)安全性、可恢復(fù)性、性能、硬盤空間成本、使用場(chǎng)景來(lái)評(píng)估。i2128資訊網(wǎng)——每日最新資訊28at.com

B:硬盤空間成本?你能具體說(shuō)說(shuō)嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

A:AOF占用空間大等....巴拉巴拉。i2128資訊網(wǎng)——每日最新資訊28at.com

B:redis 的 Key 過(guò)長(zhǎng)會(huì)影響性能嗎?i2128資訊網(wǎng)——每日最新資訊28at.com

A:額,我覺(jué)得應(yīng)該會(huì)影響性能,因?yàn)槟銌?wèn)了這個(gè)問(wèn)題,但是這個(gè)我沒(méi)太關(guān)注過(guò),對(duì)于 Key 我更在意的是可讀性。i2128資訊網(wǎng)——每日最新資訊28at.com

最后聊了一些 Redis 的數(shù)據(jù)結(jié)構(gòu),又繼續(xù)聊了一下一些特定二叉樹(shù)的概念,還問(wèn)了我對(duì)于矩陣、向量的理解,我就圍繞以前做過(guò)的天賦系統(tǒng)聊了一下矩陣。i2128資訊網(wǎng)——每日最新資訊28at.com

復(fù)盤!復(fù)盤!

為了對(duì)大家更有幫助,我把面試中回答的關(guān)鍵問(wèn)題,做了復(fù)盤和調(diào)研,總結(jié)如下:i2128資訊網(wǎng)——每日最新資訊28at.com

Actor模型

Actor模型是一種并發(fā)計(jì)算模型,用于描述并發(fā)系統(tǒng)中的實(shí)體和它們之間的通信。在Actor模型中,系統(tǒng)中的每個(gè)實(shí)體被稱為一個(gè)Actor,每個(gè)Actor都有自己的狀態(tài)和行為,并且可以通過(guò)消息傳遞與其他Actor進(jìn)行通信。i2128資訊網(wǎng)——每日最新資訊28at.com

在Actor模型中,每個(gè)Actor都是獨(dú)立的,它們之間沒(méi)有共享的內(nèi)存。Actor之間通過(guò)異步消息傳遞進(jìn)行通信,一個(gè)Actor可以向其他Actor發(fā)送消息,也可以接收其他Actor發(fā)送的消息。當(dāng)一個(gè)Actor接收到消息時(shí),它可以根據(jù)消息內(nèi)容和自身的狀態(tài)來(lái)決定如何處理消息,并可能改變自身的狀態(tài)或向其他Actor發(fā)送消息。i2128資訊網(wǎng)——每日最新資訊28at.com

Actor模型的特點(diǎn)包括:i2128資訊網(wǎng)——每日最新資訊28at.com

1. 并發(fā)性: 每個(gè)Actor都可以獨(dú)立地執(zhí)行,不受其他Actor的影響,從而實(shí)現(xiàn)并發(fā)執(zhí)行。i2128資訊網(wǎng)——每日最新資訊28at.com

2. 無(wú)共享狀態(tài): 每個(gè)Actor都有自己的狀態(tài),不與其他Actor共享內(nèi)存,避免了共享狀態(tài)帶來(lái)的并發(fā)問(wèn)題。i2128資訊網(wǎng)——每日最新資訊28at.com

3. 異步消息傳遞: Actor之間通過(guò)異步消息傳遞進(jìn)行通信,消息的發(fā)送和接收是非阻塞的,提高了系統(tǒng)的響應(yīng)性能。i2128資訊網(wǎng)——每日最新資訊28at.com

4. 面向?qū)ο螅?nbsp;每個(gè)Actor都可以看作是一個(gè)對(duì)象,具有自己的狀態(tài)和行為,可以封裝數(shù)據(jù)和方法。i2128資訊網(wǎng)——每日最新資訊28at.com

總結(jié)一下:通過(guò)使用Actor模型,可以簡(jiǎn)化并發(fā)系統(tǒng)的設(shè)計(jì)和實(shí)現(xiàn),提高系統(tǒng)的可擴(kuò)展性和可維護(hù)性。同時(shí),Actor模型也能夠有效地處理并發(fā)問(wèn)題,避免了傳統(tǒng)并發(fā)編程中常見(jiàn)的共享狀態(tài)和鎖競(jìng)爭(zhēng)的問(wèn)題。i2128資訊網(wǎng)——每日最新資訊28at.com

對(duì)比Go的GMP模型和Actor模型

Go的GMP(Goroutine, M, P)模型和Actor模型都是用于并發(fā)編程的模型,但在一些方面有所不同。i2128資訊網(wǎng)——每日最新資訊28at.com

Go的GMP模型是Go語(yǔ)言并發(fā)編程的基礎(chǔ),它通過(guò)goroutine(輕量級(jí)線程)和調(diào)度器(scheduler)來(lái)實(shí)現(xiàn)并發(fā)。GMP模型中的goroutine是Go語(yǔ)言中的并發(fā)執(zhí)行單元,它可以獨(dú)立地執(zhí)行函數(shù)或方法。調(diào)度器負(fù)責(zé)將goroutine分配給線程(P),以便并行執(zhí)行。線程(P)是操作系統(tǒng)線程的抽象,它負(fù)責(zé)執(zhí)行g(shù)oroutine。M(Machine)是Go語(yǔ)言運(yùn)行時(shí)系統(tǒng)的一部分,它管理線程的創(chuàng)建和銷毀,并提供與操作系統(tǒng)的交互。GMP模型的優(yōu)點(diǎn)是輕量級(jí)的goroutine和高效的調(diào)度器,使得并發(fā)編程變得簡(jiǎn)單且高效。i2128資訊網(wǎng)——每日最新資訊28at.com

Actor模型是一種并發(fā)編程模型,它通過(guò)將并發(fā)執(zhí)行的單元(稱為actor)之間的通信和狀態(tài)封裝在一起來(lái)實(shí)現(xiàn)并發(fā)。在Actor模型中,每個(gè)actor都是獨(dú)立的實(shí)體,它們通過(guò)消息傳遞進(jìn)行通信。每個(gè)actor都有自己的狀態(tài)和行為,并且只能通過(guò)接收和發(fā)送消息來(lái)與其他actor進(jìn)行通信。Actor模型的優(yōu)點(diǎn)是提供了一種結(jié)構(gòu)化的方式來(lái)處理并發(fā),避免了共享狀態(tài)和鎖的問(wèn)題。i2128資訊網(wǎng)——每日最新資訊28at.com

雖然GMP模型和Actor模型都是用于并發(fā)編程,但它們?cè)趯?shí)現(xiàn)方式和語(yǔ)義上有所不同。GMP模型更加底層,直接操作線程和goroutine,適用于需要更細(xì)粒度控制的場(chǎng)景。而Actor模型更加高級(jí),通過(guò)消息傳遞來(lái)實(shí)現(xiàn)并發(fā),適用于需要更結(jié)構(gòu)化和可擴(kuò)展的場(chǎng)景。i2128資訊網(wǎng)——每日最新資訊28at.com

總結(jié)起來(lái),GMP模型適用于Go語(yǔ)言中的并發(fā)編程,提供了輕量級(jí)的goroutine和高效的調(diào)度器;而Actor模型適用于一般的并發(fā)編程,通過(guò)消息傳遞來(lái)實(shí)現(xiàn)并發(fā)。i2128資訊網(wǎng)——每日最新資訊28at.com

epoll模型

epoll是一種在Linux系統(tǒng)中用于高效處理大量并發(fā)連接的I/O事件通知機(jī)制。它具有以下特點(diǎn):i2128資訊網(wǎng)——每日最新資訊28at.com

  1. 支持高并發(fā):epoll使用事件驅(qū)動(dòng)的方式,能夠同時(shí)處理大量的并發(fā)連接,適用于高并發(fā)的網(wǎng)絡(luò)應(yīng)用場(chǎng)景。
  2. 高效的事件通知機(jī)制:epoll采用了基于事件驅(qū)動(dòng)的方式,當(dāng)有事件發(fā)生時(shí),內(nèi)核會(huì)將事件通知給應(yīng)用程序,而不需要應(yīng)用程序輪詢檢查事件是否發(fā)生,從而減少了系統(tǒng)資源的消耗。
  3. 支持邊緣觸發(fā)和水平觸發(fā):epoll提供了兩種工作模式,邊緣觸發(fā)(EPOLLET)和水平觸發(fā)(EPOLLIN/EPOLLOUT)。邊緣觸發(fā)模式只在狀態(tài)發(fā)生變化時(shí)通知應(yīng)用程序,而水平觸發(fā)模式則在狀態(tài)可讀或可寫時(shí)都會(huì)通知應(yīng)用程序。
  4. 支持多種I/O事件類型:epoll可以同時(shí)監(jiān)控多種I/O事件類型,包括讀事件、寫事件、錯(cuò)誤事件等。
  5. 高效的內(nèi)核數(shù)據(jù)結(jié)構(gòu):epoll使用紅黑樹(shù)和雙向鏈表等高效的數(shù)據(jù)結(jié)構(gòu)來(lái)管理大量的文件描述符,提高了事件的處理效率。

總之,epoll模型具有高并發(fā)、高效的事件通知機(jī)制和多種I/O事件類型的支持,適用于處理大量并發(fā)連接的網(wǎng)絡(luò)應(yīng)用場(chǎng)景。i2128資訊網(wǎng)——每日最新資訊28at.com

etcd保證數(shù)據(jù)一致性

etcd通過(guò)使用Raft一致性算法來(lái)保證數(shù)據(jù)的一致性。 Raft是一種分布式一致性算法,它將集群中的節(jié)點(diǎn)分為L(zhǎng)eader、Follower和Candidate三種角色,通過(guò)選舉機(jī)制選出Leader節(jié)點(diǎn)來(lái)處理客戶端的請(qǐng)求。i2128資訊網(wǎng)——每日最新資訊28at.com

當(dāng)客戶端向etcd發(fā)送寫請(qǐng)求時(shí),Leader節(jié)點(diǎn)會(huì)將該請(qǐng)求復(fù)制到其他節(jié)點(diǎn)的日志中,并等待大多數(shù)節(jié)點(diǎn)確認(rèn)接收到該日志條目。一旦大多數(shù)節(jié)點(diǎn)確認(rèn)接收到該日志條目,Leader節(jié)點(diǎn)會(huì)將該請(qǐng)求應(yīng)用到自己的狀態(tài)機(jī)中,并將結(jié)果返回給客戶端。同時(shí),Leader節(jié)點(diǎn)會(huì)通知其他節(jié)點(diǎn)將該請(qǐng)求應(yīng)用到自己的狀態(tài)機(jī)中。i2128資訊網(wǎng)——每日最新資訊28at.com

如果Leader節(jié)點(diǎn)失去連接或崩潰,剩余的節(jié)點(diǎn)會(huì)通過(guò)選舉機(jī)制選出新的Leader節(jié)點(diǎn)。新的Leader節(jié)點(diǎn)會(huì)根據(jù)自己的日志和其他節(jié)點(diǎn)的日志進(jìn)行比較,保證自己的日志是最新的,并將缺失的日志條目復(fù)制給其他節(jié)點(diǎn),以保持?jǐn)?shù)據(jù)的一致性。i2128資訊網(wǎng)——每日最新資訊28at.com

通過(guò)Raft算法,etcd能夠保證數(shù)據(jù)在集群中的一致性,并且在Leader節(jié)點(diǎn)失效時(shí)能夠快速選舉出新的Leader節(jié)點(diǎn),保證系統(tǒng)的可用性和數(shù)據(jù)的一致性。i2128資訊網(wǎng)——每日最新資訊28at.com

redis的落盤方案

Redis的落盤方案主要有兩種:RDB(Redis Database)和AOF(Append Only File)。i2128資訊網(wǎng)——每日最新資訊28at.com

  1. RDB(Redis Database):RDB是Redis默認(rèn)的持久化方式。它通過(guò)將Redis的內(nèi)存數(shù)據(jù)快照保存到磁盤上的二進(jìn)制文件中來(lái)實(shí)現(xiàn)持久化。RDB的優(yōu)點(diǎn)是快速和緊湊,適合用于備份和恢復(fù)數(shù)據(jù)。RDB的缺點(diǎn)是在發(fā)生故障時(shí)可能會(huì)丟失一部分?jǐn)?shù)據(jù),因?yàn)镽DB是定期進(jìn)行持久化的,而不是實(shí)時(shí)的。
  2. AOF(Append Only File):AOF是另一種持久化方式,它通過(guò)將Redis的寫操作追加到文件末尾來(lái)記錄數(shù)據(jù)的變化。AOF的優(yōu)點(diǎn)是可以提供更好的數(shù)據(jù)安全性,因?yàn)樗涗浟嗣總€(gè)寫操作,可以在發(fā)生故障時(shí)進(jìn)行恢復(fù)。AOF的缺點(diǎn)是相對(duì)于RDB來(lái)說(shuō),文件體積較大,恢復(fù)數(shù)據(jù)的速度較慢。

在實(shí)際應(yīng)用中,可以根據(jù)需求選擇適合的落盤方案。如果對(duì)數(shù)據(jù)的安全性要求較高,可以選擇AOF方式;如果對(duì)數(shù)據(jù)的實(shí)時(shí)性要求較高,可以選擇RDB方式。另外,也可以同時(shí)使用RDB和AOF兩種方式,以提供更好的數(shù)據(jù)保護(hù)和恢復(fù)能力。i2128資訊網(wǎng)——每日最新資訊28at.com

本文轉(zhuǎn)載自微信公眾號(hào)「 程序員升級(jí)打怪之旅」,作者「王中陽(yáng)Go」,可以通過(guò)以下二維碼關(guān)注。i2128資訊網(wǎng)——每日最新資訊28at.com

i2128資訊網(wǎng)——每日最新資訊28at.com

轉(zhuǎn)載本文請(qǐng)聯(lián)系「 程序員升級(jí)打怪之旅」公眾號(hào)。i2128資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-5769-0.html「Go面經(jīng)」算法 并發(fā)模型 緩存落盤 etcd actor模型

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: 每個(gè)前端開(kāi)發(fā)者都應(yīng)知道的14個(gè)實(shí)用網(wǎng)站

下一篇: Go-Zero 是如何實(shí)現(xiàn)令牌桶限流的?

標(biāo)簽:
  • 熱門焦點(diǎn)
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
欧美一区二区成人| 日韩亚洲国产精品| 国产精品理论片在线观看| 国产精品久久91| 国产欧美一区二区精品秋霞影院| 国内精品久久久久久久影视蜜臀| 在线精品高清中文字幕| 洋洋av久久久久久久一区| 亚洲欧美日韩区| 久久久噜噜噜久久中文字免| 欧美国产日本高清在线| 国产精品久久97| 黄色影院成人| 一本色道久久加勒比88综合| 欧美在线亚洲综合一区| 欧美h视频在线| 国产精品麻豆欧美日韩ww| 激情久久婷婷| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲国产成人在线播放| 久久综合九色综合久99| 欧美精品v日韩精品v韩国精品v | 欧美高清视频在线播放| 欧美特黄视频| 黄色亚洲免费| 中日韩视频在线观看| 久久精品二区三区| 欧美日韩国产天堂| 韩国成人福利片在线播放| 99在线|亚洲一区二区| 欧美一级专区免费大片| 欧美国产激情| 国产综合色精品一区二区三区| 日韩视频三区| 久久免费视频一区| 国产精品美女| 在线观看一区二区视频| 性色一区二区| 黄色欧美日韩| 欧美日韩综合久久| 先锋影音一区二区三区| 国产精品国产三级国产普通话三级| 欧美激情视频在线播放| 国产欧美一区二区三区在线看蜜臀| 亚洲国产日韩欧美在线动漫| 午夜精品久久久久久久男人的天堂| 欧美刺激性大交免费视频| 国产日产欧美一区| 一区二区精品在线观看| 欧美v亚洲v综合ⅴ国产v| 国产日韩欧美三级| 亚洲一区二区三区视频播放| 欧美a级在线| 国产一区自拍视频| 亚洲综合视频1区| 欧美日产一区二区三区在线观看| 伊人狠狠色丁香综合尤物| 午夜精品视频| 国产精品国产三级欧美二区| 亚洲卡通欧美制服中文| 免费91麻豆精品国产自产在线观看| 国产免费观看久久黄| 亚洲视频在线观看| 欧美日韩一区不卡| 亚洲高清在线观看| 亚洲国产精品成人综合| 国产一二三精品| 精品成人一区二区三区| 国产精品乱码一区二三区小蝌蚪| 美日韩精品免费| 国产亚洲综合精品| 亚洲男同1069视频| 欧美日韩免费一区二区三区视频 | 欧美福利电影网| 影音先锋欧美精品| 久久久久.com| 激情综合在线| 久久久亚洲影院你懂的| 国产一区二区三区四区| 欧美一区二区免费观在线| 国产精品日韩一区二区| 亚洲欧美日韩一区二区| 国产精品一区二区三区久久| 亚洲午夜在线| 国产精品久久久久av| 亚洲永久免费av| 国产精品美女主播| 午夜精品一区二区三区在线播放| 国产精品视频99| 香蕉久久夜色精品国产使用方法| 欧美日韩国产限制| 精品9999| 亚洲一区二区在线免费观看视频 | 久久久久久伊人| 伊人久久大香线蕉综合热线 | 欧美精品亚洲二区| 99精品国产高清一区二区 | 国色天香一区二区| 久久综合影视| 亚洲人成网站精品片在线观看| 欧美不卡一卡二卡免费版| 亚洲日产国产精品| 欧美色大人视频| 亚洲欧美资源在线| 国模精品一区二区三区| 美女图片一区二区| 亚洲精品一区二区在线观看| 欧美三区视频| 欧美一区在线看| 在线精品福利| 欧美日韩国产成人精品| 亚洲一区二区三区免费观看| 国产精品麻豆va在线播放| 久久国产精品一区二区三区四区 | 在线观看日韩一区| 欧美国产日韩在线观看| 可以看av的网站久久看| 国产欧美日韩麻豆91| 亚洲一区二区三区乱码aⅴ蜜桃女| 久久男人av资源网站| 国产精品美女一区二区| 国产人成精品一区二区三| 久久精品青青大伊人av| 精品9999| 欧美日韩国产高清视频| 亚洲制服av| 红桃视频亚洲| 欧美激情按摩在线| 午夜精品久久久久久久久久久久久 | 久久国产夜色精品鲁鲁99| 影音先锋亚洲视频| 欧美日韩你懂的| 欧美在线国产精品| 亚洲日本黄色| 国产农村妇女精品一二区| 免费观看国产成人| 亚洲免费中文| 亚洲国产精品一区在线观看不卡 | 午夜久久99| 国产视频一区欧美| 欧美一区二区三区在线视频| 最近中文字幕日韩精品 | 在线观看欧美一区| 欧美网站在线| 蜜臀久久99精品久久久画质超高清 | 在线成人激情| 欧美新色视频| 另类图片国产| 亚洲欧美日韩国产另类专区| 亚洲电影有码| 国产精品视频免费在线观看| 免费看的黄色欧美网站| 亚洲欧美春色| 亚洲精品网址在线观看| 国产亚洲一区二区三区在线观看| 欧美精品一区二区三| 久久狠狠一本精品综合网| 一本色道久久综合亚洲精品高清 | 99在线精品免费视频九九视| 精品动漫3d一区二区三区免费版 | 99re热精品| 亚洲大黄网站| 国产日韩av高清| 欧美性视频网站| 欧美风情在线| 国产亚洲精品自拍| 亚洲国产一区二区三区青草影视 | 99亚洲精品| 激情欧美丁香| 欧美在线免费播放| 亚洲精选久久| 伊人婷婷久久| 国产人妖伪娘一区91| 欧美日韩免费一区| 欧美丰满少妇xxxbbb| 久久久久青草大香线综合精品| 亚洲自拍偷拍色片视频| 亚洲精品永久免费精品| 在线欧美福利| 黄色影院成人| 国产视频欧美视频| 国产精品久久久| 欧美日韩精品久久久| 欧美国产日本| 蜜乳av另类精品一区二区| 久久久久久久一区二区三区| 欧美亚洲一级片| 亚洲一级二级在线| av成人免费| 亚洲人成小说网站色在线| 亚洲电影视频在线| 精品av久久久久电影| 国产一区二区三区日韩| 国产日韩欧美制服另类| 国产精品普通话对白| 国产精品久久久久99| 欧美亚洲不卡| 99国产精品私拍| 国内欧美视频一区二区| 国产精品午夜电影| 国产精品久久久久毛片软件| 欧美性大战久久久久久久| 欧美日韩一视频区二区| 欧美视频不卡中文|