亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring sentinel哨兵模式相關(guān)原理解析

 更新時(shí)間:2020年11月04日 09:30:54   作者:周曉楠  
這篇文章主要介紹了Spring sentinel哨兵模式相關(guān)原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

1. sentinel作用

1. 當(dāng)用Redis做主從方案時(shí),假如master宕機(jī),Redis本身無(wú)法自動(dòng)進(jìn)行主備切換

2. 而Redis-sentinel本身也是一個(gè)獨(dú)立運(yùn)行的進(jìn)程,它能監(jiān)控多個(gè)master-slave集群,發(fā)現(xiàn)master宕機(jī)后能進(jìn)行自動(dòng)切換。

2. sentinel原理

1. sentinel負(fù)責(zé)持續(xù)監(jiān)控主節(jié)點(diǎn)的健康,當(dāng)主節(jié)掛掉時(shí),自動(dòng)選擇一個(gè)最優(yōu)的從節(jié)點(diǎn)切換成主節(jié)點(diǎn)

2. 從節(jié)點(diǎn)來(lái)連接集群時(shí)會(huì)首先連接sentinel,通過(guò)sentinel來(lái)查詢主節(jié)點(diǎn)的地址

3. 當(dāng)主節(jié)點(diǎn)發(fā)生故障時(shí),sentinel會(huì)將最新的主節(jié)點(diǎn)地址告訴客戶端,可以實(shí)現(xiàn)無(wú)需重啟自動(dòng)切換redis

3. Sentinel支持集群

1. 只使用單個(gè)sentinel進(jìn)程來(lái)監(jiān)控redis集群是不可靠的,當(dāng)sentinel進(jìn)程宕掉后sentinel本身也有單點(diǎn)問(wèn)題

2. 如果有多個(gè)sentinel,redis的客戶端可以隨意地連接任意一個(gè)sentinel來(lái)獲得關(guān)于redis集群中的信息。

4. Sentinel版本

1. Sentinel當(dāng)前穩(wěn)定版本稱為Sentinel 2,Redis2.8和Redis3.0附帶穩(wěn)定的哨兵版本

2. 安裝完redis-3.2.8后,redis-3.2.8/src/redis-sentinel啟動(dòng)程序 redis-3.2.8/sentinel.conf是配置文件。

5. 運(yùn)行sentinel兩種方式(效果相同)

法1:redis-sentinel /path/to/sentinel.conf

法2:redis-server /path/to/sentinel.conf --sentinel

1. 以上兩種方式,都必須指定一個(gè)sentinel的配置文件sentinel.conf,如果不指定,將無(wú)法啟動(dòng)sentinel。

2. sentinel默認(rèn)監(jiān)聽(tīng)26379端口,所以運(yùn)行前必須確定該端口沒(méi)有被別的進(jìn)程占用。

6. sentinel.conf配置文件說(shuō)明

1. 配置文件只需要配置master的信息就好啦,不用配置slave的信息,因?yàn)閟lave能夠被自動(dòng)檢測(cè)到

2. 需要注意的是,配置文件在sentinel運(yùn)行期間是會(huì)被動(dòng)態(tài)修改的,例如當(dāng)發(fā)生主備切換時(shí)候,配置文件中的master會(huì)被修改為另外一個(gè)slave。

3. 這樣,之后sentinel如果重啟時(shí),就可以根據(jù)這個(gè)配置來(lái)恢復(fù)其之前所監(jiān)控的redis集群的狀態(tài)。

# sentinel.conf 配置說(shuō)明
sentinel monitor mymaster 127.0.0.1 6379 2
sentinel down-after-milliseconds mymaster 60000
sentinel failover-timeout mymaster 180000
sentinel parallel-syncs mymaster 1

7. 配置傳播

1. 一旦一個(gè)sentinel成功地對(duì)一個(gè)master進(jìn)行了failover,它將會(huì)把關(guān)于master的最新配置通過(guò)廣播形式通知其它sentinel,其它的sentinel則更新對(duì)應(yīng)master的配置。

2. 一個(gè)faiover要想被成功實(shí)行,sentinel必須能夠向選為master的slave發(fā)送SLAVE OF NO ONE命令,然后能夠通過(guò)INFO命令看到新master的配置信息。

3. 當(dāng)將一個(gè)slave選舉為master并發(fā)送SLAVE OF NO ONE`后,即使其它的slave還沒(méi)針對(duì)新master重新配置自己,failover也被認(rèn)為是成功了的。

因?yàn)槊恳粋€(gè)配置都有一個(gè)版本號(hào),所以以版本號(hào)最大的那個(gè)為標(biāo)準(zhǔn):

  1)假設(shè)有一個(gè)名為mymaster的地址為192.168.1.50:6379。

  2)一開始,集群中所有的sentinel都知道這個(gè)地址,于是為mymaster的配置打上版本號(hào)1。

  3)一段時(shí)候后mymaster死了,有一個(gè)sentinel被授權(quán)用版本號(hào)2對(duì)其進(jìn)行failover。

  4)如果failover成功了,假設(shè)地址改為了192.168.1.50:9000,此時(shí)配置的版本號(hào)為2

  5)進(jìn)行failover的sentinel會(huì)將新配置廣播給其他的sentinel,發(fā)現(xiàn)新配置的版本號(hào)為2時(shí),版本號(hào)變大了,說(shuō)明配置更新了,于是就會(huì)采用最新的版本號(hào)為2的配置。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 源碼解析Java類加載器

    源碼解析Java類加載器

    這篇文章主要給大家介紹了Java類加載器源碼解析的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • java后端PayPal支付實(shí)現(xiàn)教程

    java后端PayPal支付實(shí)現(xiàn)教程

    本文主要介紹了java后端PayPal支付實(shí)現(xiàn)教程,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • java根據(jù)擴(kuò)展名獲取系統(tǒng)圖標(biāo)和文件圖標(biāo)示例

    java根據(jù)擴(kuò)展名獲取系統(tǒng)圖標(biāo)和文件圖標(biāo)示例

    這篇文章主要介紹了java根據(jù)擴(kuò)展名獲取系統(tǒng)圖標(biāo)和文件圖標(biāo)示例,需要的朋友可以參考下
    2014-03-03
  • jcl與jul?log4j1?log4j2?logback日志系統(tǒng)機(jī)制及集成原理

    jcl與jul?log4j1?log4j2?logback日志系統(tǒng)機(jī)制及集成原理

    這篇文章主要介紹了jcl與jul?log4j1?log4j2?logback的集成原理,Apache?Commons-logging?通用日志框架與日志系統(tǒng)的機(jī)制,有需要的朋友可以借鑒參考下
    2022-03-03
  • java高并發(fā)之線程組詳解

    java高并發(fā)之線程組詳解

    這篇文章主要介紹了java高并發(fā)之線程組,Java提供了ThreadGroup類來(lái)控制一個(gè)線程組,一個(gè)線程組可以通過(guò)線程對(duì)象來(lái)創(chuàng)建,也可以由其他線程組來(lái)創(chuàng)建,生成一個(gè)樹形結(jié)構(gòu)的線程,需要的朋友可以參考下
    2021-10-10
  • java.lang.ArrayStoreException異常的解決方案

    java.lang.ArrayStoreException異常的解決方案

    這篇文章主要介紹了java.lang.ArrayStoreException異常的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 淺談Hibernate對(duì)象狀態(tài)之間的神奇轉(zhuǎn)換

    淺談Hibernate對(duì)象狀態(tài)之間的神奇轉(zhuǎn)換

    這篇文章主要介紹了淺談Hibernate對(duì)象狀態(tài)之間的神奇轉(zhuǎn)換,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • Spring中的@DependsOn注解使用解析

    Spring中的@DependsOn注解使用解析

    這篇文章主要介紹了Spring中的@DependsOn注解使用解析,@DependsOn注解可以定義在類和方法上,意思是我這個(gè)組件要依賴于另一個(gè)組件,也就是說(shuō)被依賴的組件會(huì)比該組件先注冊(cè)到IOC容器中,需要的朋友可以參考下
    2024-01-01
  • SpringMVC結(jié)合Jcrop實(shí)現(xiàn)圖片裁剪

    SpringMVC結(jié)合Jcrop實(shí)現(xiàn)圖片裁剪

    這篇文章主要介紹了SpringMVC結(jié)合Jcrop實(shí)現(xiàn)圖片裁剪的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • Java使用抽象工廠模式實(shí)現(xiàn)的肯德基消費(fèi)案例詳解

    Java使用抽象工廠模式實(shí)現(xiàn)的肯德基消費(fèi)案例詳解

    這篇文章主要介紹了Java使用抽象工廠模式實(shí)現(xiàn)的肯德基消費(fèi)案例,較為詳細(xì)的分析了抽象工廠模式的定義、原理并結(jié)合實(shí)例形式分析了Java使用抽象工廠模式實(shí)現(xiàn)肯德基消費(fèi)案例的步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2018-05-05

最新評(píng)論