一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫(kù)技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫(kù) - Redis - 分布式鎖為什么要選擇Zookeeper而不是Redis?看完這篇你就明白了

分布式鎖為什么要選擇Zookeeper而不是Redis?看完這篇你就明白了

2021-08-05 16:46宇的季節(jié) Redis

Zookeeper的機(jī)制可以保證分布式鎖實(shí)現(xiàn)業(yè)務(wù)代碼簡(jiǎn)單,成本低,Redis如果要解決分布式鎖的問(wèn)題,對(duì)于一些復(fù)雜的情況,很難解決,成本較高,這篇文章重點(diǎn)給大家介紹分布式鎖選擇Zookeeper 而不是Redis的理由,一起看看吧

在分布式的應(yīng)用中,為了防止單點(diǎn)故障,保障高可用,通常會(huì)采用主從結(jié)構(gòu),當(dāng)主節(jié)點(diǎn)掛掉后,從節(jié)點(diǎn)可以代替主節(jié)點(diǎn)提供服務(wù)。

Redis通過(guò)復(fù)制 + sentinel哨兵來(lái)實(shí)現(xiàn)主從模式。

Zookeeper通過(guò)replicated mode復(fù)制模式來(lái)實(shí)現(xiàn)主從模式。

單從結(jié)構(gòu)上看,Redis和Zookeeper都是主從架構(gòu),那Zookeeper的優(yōu)勢(shì)是什么?為什么要選擇Zookeeper?難道只是因?yàn)閆ookeeper是目錄結(jié)構(gòu),Redis是K-V結(jié)構(gòu)嗎?

同步機(jī)制的不同

 

 

Redis

Redis在給從節(jié)點(diǎn)同步數(shù)據(jù)時(shí),正常情況是增量同步,也就是主節(jié)點(diǎn)的數(shù)據(jù)修改語(yǔ)句(DML)會(huì)異步的同步給從節(jié)點(diǎn)。Redis的數(shù)據(jù)同步?jīng)]有保障數(shù)據(jù)一致性的機(jī)制,也就是說(shuō),一條DML在主節(jié)點(diǎn)執(zhí)行成功時(shí),不能保障其他從節(jié)點(diǎn)成功執(zhí)行了這條數(shù)據(jù),這就會(huì)造成一個(gè)問(wèn)題,如果在數(shù)據(jù)沒(méi)有同步到從節(jié)點(diǎn)時(shí),主節(jié)點(diǎn)掛掉,就會(huì)產(chǎn)生數(shù)據(jù)丟失的情況。

Zookeeper

Zookeeper使用類(lèi)paxos算法來(lái)保障數(shù)據(jù)的一致性。簡(jiǎn)單的講,當(dāng)一個(gè)DML語(yǔ)句發(fā)送給主節(jié)點(diǎn)時(shí),Zookeeper需要保證一半以上的節(jié)點(diǎn)接收到數(shù)據(jù),才會(huì)返回成功。并且當(dāng)主節(jié)點(diǎn)掛掉,從節(jié)點(diǎn)重新選舉時(shí),同步到最新的數(shù)據(jù)的節(jié)點(diǎn)會(huì)有優(yōu)先選舉權(quán)。

舉個(gè)例子:

一個(gè)4節(jié)點(diǎn)Zookeeper(A、B、C、D),A是主節(jié)點(diǎn),當(dāng)執(zhí)行一個(gè)create語(yǔ)句成功時(shí),至少有3臺(tái)節(jié)點(diǎn)執(zhí)行成功(一半以上),例如A、C、D成功。此時(shí)如果A節(jié)點(diǎn)掛了,B、C、D進(jìn)行選舉,由于C、D都執(zhí)行成功了create語(yǔ)句,B沒(méi)有執(zhí)行,C、D的數(shù)據(jù)更加新,具有優(yōu)先選舉權(quán),再根據(jù)名稱(chēng)排序,選擇C做為主節(jié)點(diǎn)。在整個(gè)選舉過(guò)程中,服務(wù)不可用,選舉完成后,C節(jié)點(diǎn)和A節(jié)點(diǎn)數(shù)據(jù)一致,不會(huì)出現(xiàn)丟失的情況。

分布式鎖

 

 

要實(shí)現(xiàn)分布式鎖,需要滿(mǎn)足一些要求:

  • 只能有一個(gè)服務(wù)的一個(gè)線(xiàn)程能獲取鎖
  • 一個(gè)持有鎖的線(xiàn)程掛掉后,鎖應(yīng)該被釋放,用來(lái)給其他線(xiàn)程用
  • 一個(gè)持有鎖的線(xiàn)程沒(méi)執(zhí)行完,鎖不能釋放
  • 鎖釋放后,其他等待者可以繼續(xù)爭(zhēng)搶
  • 管理鎖的主節(jié)點(diǎn)(Redis或Zookeeper)掛了,重新選舉后,不影響鎖的持有情況

Redis解決方案

問(wèn)題1、問(wèn)題2:使用“SET key value EX seconds NX”語(yǔ)句獲取鎖并設(shè)置過(guò)期時(shí)間

問(wèn)題3:另開(kāi)一個(gè)監(jiān)控線(xiàn)程,監(jiān)控主線(xiàn)程執(zhí)行情況,用來(lái)延長(zhǎng)過(guò)期時(shí)間

問(wèn)題4:等待線(xiàn)程定時(shí)檢查鎖的持有情況

問(wèn)題5:暫無(wú)或者解決成本很高,需要自己實(shí)現(xiàn)類(lèi)paxos的算法

Zookeeper解決方案

通過(guò)創(chuàng)建臨時(shí)節(jié)點(diǎn)可以解決問(wèn)題1,2,3

watch機(jī)制可以解決問(wèn)題4,并且相比定時(shí)檢查,watch可以做到更高實(shí)時(shí)性

zookeeper的paxos同步機(jī)制保障了節(jié)點(diǎn)間數(shù)據(jù)一致性,即使主節(jié)點(diǎn)掛掉,也可以保障數(shù)據(jù)不丟,可以解決問(wèn)題5

對(duì)比可以發(fā)現(xiàn):

Zookeeper的機(jī)制可以保證分布式鎖實(shí)現(xiàn)業(yè)務(wù)代碼簡(jiǎn)單,成本低。

Redis如果要解決分布式鎖的問(wèn)題,對(duì)于一些復(fù)雜的情況,很難解決,成本較高。

以上就是分布式鎖為什么要選擇Zookeeper而不是Redis?看完這篇你就明白了的詳細(xì)內(nèi)容,更多關(guān)于分布式鎖Zookeeper Redis的資料請(qǐng)關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://www.cnblogs.com/chenkeyu/p/14793627.html

延伸 · 閱讀

精彩推薦
  • RedisRedis 事務(wù)知識(shí)點(diǎn)相關(guān)總結(jié)

    Redis 事務(wù)知識(shí)點(diǎn)相關(guān)總結(jié)

    這篇文章主要介紹了Redis 事務(wù)相關(guān)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用Redis,感興趣的朋友可以了解下...

    AsiaYe8232021-07-28
  • Redisredis實(shí)現(xiàn)排行榜功能

    redis實(shí)現(xiàn)排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用來(lái)實(shí)現(xiàn)排行榜功能,本文就來(lái)簡(jiǎn)單的介紹一下如何使用,具有一定的參考價(jià)值,感興趣的小伙伴們...

    乘月歸5022021-08-05
  • RedisRedis全量復(fù)制與部分復(fù)制示例詳解

    Redis全量復(fù)制與部分復(fù)制示例詳解

    這篇文章主要給大家介紹了關(guān)于Redis全量復(fù)制與部分復(fù)制的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Redis爬蟲(chóng)具有一定的參考學(xué)習(xí)...

    豆子先生5052019-11-27
  • RedisRedis如何實(shí)現(xiàn)數(shù)據(jù)庫(kù)讀寫(xiě)分離詳解

    Redis如何實(shí)現(xiàn)數(shù)據(jù)庫(kù)讀寫(xiě)分離詳解

    Redis的主從架構(gòu),能幫助我們實(shí)現(xiàn)讀多,寫(xiě)少的情況,下面這篇文章主要給大家介紹了關(guān)于Redis如何實(shí)現(xiàn)數(shù)據(jù)庫(kù)讀寫(xiě)分離的相關(guān)資料,文中通過(guò)示例代碼介紹...

    羅兵漂流記6092019-11-11
  • RedisRedis的配置、啟動(dòng)、操作和關(guān)閉方法

    Redis的配置、啟動(dòng)、操作和關(guān)閉方法

    今天小編就為大家分享一篇Redis的配置、啟動(dòng)、操作和關(guān)閉方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧 ...

    大道化簡(jiǎn)5312019-11-14
  • Redisredis 交集、并集、差集的具體使用

    redis 交集、并集、差集的具體使用

    這篇文章主要介紹了redis 交集、并集、差集的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友...

    xiaojin21cen10152021-07-27
  • Redis詳解Redis復(fù)制原理

    詳解Redis復(fù)制原理

    與大多數(shù)db一樣,Redis也提供了復(fù)制機(jī)制,以滿(mǎn)足故障恢復(fù)和負(fù)載均衡等需求。復(fù)制也是Redis高可用的基礎(chǔ),哨兵和集群都是建立在復(fù)制基礎(chǔ)上實(shí)現(xiàn)高可用的...

    李留廣10222021-08-09
  • Redisredis中如何使用lua腳本讓你的靈活性提高5個(gè)逼格詳解

    redis中如何使用lua腳本讓你的靈活性提高5個(gè)逼格詳解

    這篇文章主要給大家介紹了關(guān)于redis中如何使用lua腳本讓你的靈活性提高5個(gè)逼格的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具...

    一線(xiàn)碼農(nóng)5812019-11-18
主站蜘蛛池模板: 我的妹妹最近有点怪在线观看 | 99精品视频在线观看免费播放 | 67194久久| 久久久久久久国产精品视频 | 精品欧美日韩一区二区三区 | 国内小情侣一二三区在线视频 | 免费高清视频免费观看 | 欧美午夜视频一区二区三区 | 欧美成人免费观看bbb | 精品久久免费观看 | 91精品久久一区二区三区 | 国产一区二区免费不卡在线播放 | 色噜噜 男人的天堂在线观看 | 亚洲欧美精品一区二区 | 黑人粗长大战亚洲女 | 91精品国产高清久久久久久91 | 久久亚洲免费视频 | 日本午夜大片免费观看视频 | 欧美贵妇vs高跟办公室 | 天天干天天日天天射天天操毛片 | 亚洲 欧美 国产 日韩 字幕 | 美女脱小内内给男生摸j | 欧美四虎影院 | 国产第一综合另类色区奇米 | 卫生间被教官做好爽HH视频 | 亚洲国内精品久久 | 日本天堂视频在线观看 | 黑人同学征服教师麻麻 | ts人妖系列在线专区 | avtt天堂在线 | 日韩无砖专区2020在线 | 欧美操屁股 | 国产99视频精品免费视频7 | 暖暖免费高清完整版观看日本 | 免费高清视频日本 | 2021国产麻豆剧传媒新片 | 国内精品久久久久久久久久久久 | 久久精品亚洲精品国产欧美 | 911色_911色sss在线观看 | 高清不卡免费一区二区三区 | kk4444了欧美|