日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

Redis 复制、Sentinel的搭建和原理说明

發(fā)布時(shí)間:2023/12/10 数据库 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Redis 复制、Sentinel的搭建和原理说明 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Redis 復(fù)制、Sentinel的搭建和原理說明

轉(zhuǎn)自:Redis 復(fù)制、Sentinel的搭建和原理說明

背景:

Redis-Sentinel是Redis官方推薦的高可用性(HA)解決方案,當(dāng)用Redis做Master-slave的高可用方案時(shí),假如master宕機(jī)了,Redis本身(包括它的很多客戶端)都沒有實(shí)現(xiàn)自動(dòng)進(jìn)行主備切換,而Redis-sentinel本身也是一個(gè)獨(dú)立運(yùn)行的進(jìn)程,它能監(jiān)控多個(gè)master-slave集群,發(fā)現(xiàn)master宕機(jī)后能進(jìn)行自動(dòng)切換,更多的信息見前一篇說明。它的主要功能有以下幾點(diǎn):

  • 不時(shí)地監(jiān)控redis是否按照預(yù)期良好地運(yùn)行;
  • 如果發(fā)現(xiàn)某個(gè)redis節(jié)點(diǎn)運(yùn)行出現(xiàn)狀況,能夠通知另外一個(gè)進(jìn)程(例如它的客戶端);
  • 能夠進(jìn)行自動(dòng)切換。當(dāng)一個(gè)master節(jié)點(diǎn)不可用時(shí),能夠選舉出master的多個(gè)slave(如果有超過一個(gè)slave的話)中的一個(gè)來作為新的master,其它的slave節(jié)點(diǎn)會(huì)將它所追隨的master的地址改為被提升為master的slave的新地址。
  • Redis-Replication

    1)搭建

    復(fù)制的配置很簡單,就一個(gè)參數(shù):

    slaveof <主數(shù)據(jù)庫IP> <端口>

    可以添加在配置文件里,也可以在命令行中執(zhí)行。如主數(shù)據(jù)庫IP是192.168.200.25 端口是6379:(配置多臺(tái)從數(shù)據(jù)庫的方法也一樣)

    slaveof 192.168.200.25 6379

    注意:通過命令行進(jìn)行的復(fù)制,在主從斷開或則主從重啟之后復(fù)制信息會(huì)丟失,即不能保證持久復(fù)制,需要再次執(zhí)行slaveof。但是在配置文件里寫死slaveof不會(huì)有該問題。默認(rèn)情況下從庫是只讀的,不能進(jìn)行修改,需要修改需要設(shè)置配置文件中的slave-read-only為no。在命令行里執(zhí)行slaveof no one可以讓一個(gè)從庫變成主庫。

    2)原理

    執(zhí)行步驟:

  • 從數(shù)據(jù)庫向主數(shù)據(jù)庫發(fā)送sync命令。

  • 主數(shù)據(jù)庫接收sync命令后,執(zhí)行BGSAVE命令(保存快照),創(chuàng)建一個(gè)RDB文件,在創(chuàng)建RDB文件期間的命令將保存在緩沖區(qū)中。

  • 當(dāng)主數(shù)據(jù)庫執(zhí)行完BGSAVE時(shí),會(huì)向從數(shù)據(jù)庫發(fā)送RDB文件,而從數(shù)據(jù)庫會(huì)接收并載入該文件。

  • 主數(shù)據(jù)庫將緩沖區(qū)的所有寫命令發(fā)給從服務(wù)器執(zhí)行。

  • 以上處理完之后,之后主數(shù)據(jù)庫每執(zhí)行一個(gè)寫命令,都會(huì)將被執(zhí)行的寫命令發(fā)送給從數(shù)據(jù)庫。

  • 注意:在Redis2.8之前,主從斷線或則重啟之后再重連接,都需要做一次完整的sync操作(5步驟),即使斷線期間只有幾條的更新操作或則是沒有操作,導(dǎo)致系統(tǒng)資源極度浪費(fèi)。Redis2.8之后,會(huì)用一個(gè)psync來替換sync,不會(huì)進(jìn)行完成的sync操作,只需要同步斷線期間的記錄。相關(guān)參數(shù):repl-backlog-size、repl-backlog-ttl

    大致的示意圖如下:

    3)相關(guān)的參數(shù),注釋掉的參數(shù)都是使用默認(rèn)值。

    ################################# REPLICATION ################################# #復(fù)制選項(xiàng),slave復(fù)制對(duì)應(yīng)的master。 # slaveof <masterip> <masterport>#如果master設(shè)置了requirepass,那么slave要連上master,需要有master的密碼才行。masterauth就是用來配置master的密碼,這樣可以在連上master后進(jìn)行認(rèn)證。 # masterauth <master-password>#當(dāng)從庫同主機(jī)失去連接或者復(fù)制正在進(jìn)行,從機(jī)庫有兩種運(yùn)行方式:1) 如果slave-serve-stale-data設(shè)置為yes(默認(rèn)設(shè)置),從庫會(huì)繼續(xù)響應(yīng)客戶端的請(qǐng)求。2) 如果slave-serve-stale-data設(shè)置為no,除去INFO和SLAVOF命令之外的任何請(qǐng)求都會(huì)返回一個(gè)錯(cuò)誤”SYNC with master in progress”。 slave-serve-stale-data yes#作為從服務(wù)器,默認(rèn)情況下是只讀的(yes),可以修改成NO,用于寫(不建議)。 slave-read-only yes#是否使用socket方式復(fù)制數(shù)據(jù)。目前redis復(fù)制提供兩種方式,disk和socket。如果新的slave連上來或者重連的slave無法部分同步,就會(huì)執(zhí)行全量同步,master會(huì)生成rdb文件。有2種方式:disk方式是master創(chuàng)建一個(gè)新的進(jìn)程把rdb文件保存到磁盤,再把磁盤上的rdb文件傳遞給slave。socket是master創(chuàng)建一個(gè)新的進(jìn)程,直接把rdb文件以socket的方式發(fā)給slave。disk方式的時(shí)候,當(dāng)一個(gè)rdb保存的過程中,多個(gè)slave都能共享這個(gè)rdb文件。socket的方式就的一個(gè)個(gè)slave順序復(fù)制。在磁盤速度緩慢,網(wǎng)速快的情況下推薦用socket方式。 repl-diskless-sync no#diskless復(fù)制的延遲時(shí)間,防止設(shè)置為0。一旦復(fù)制開始,節(jié)點(diǎn)不會(huì)再接收新slave的復(fù)制請(qǐng)求直到下一個(gè)rdb傳輸。所以最好等待一段時(shí)間,等更多的slave連上來。 repl-diskless-sync-delay 5#slave根據(jù)指定的時(shí)間間隔向服務(wù)器發(fā)送ping請(qǐng)求。時(shí)間間隔可以通過 repl_ping_slave_period 來設(shè)置,默認(rèn)10秒。 # repl-ping-slave-period 10#復(fù)制連接超時(shí)時(shí)間。master和slave都有超時(shí)時(shí)間的設(shè)置。master檢測(cè)到slave上次發(fā)送的時(shí)間超過repl-timeout,即認(rèn)為slave離線,清除該slave信息。slave檢測(cè)到上次和master交互的時(shí)間超過repl-timeout,則認(rèn)為master離線。需要注意的是repl-timeout需要設(shè)置一個(gè)比repl-ping-slave-period更大的值,不然會(huì)經(jīng)常檢測(cè)到超時(shí)。 # repl-timeout 60#是否禁止復(fù)制tcp鏈接的tcp nodelay參數(shù),可傳遞yes或者no。默認(rèn)是no,即使用tcp nodelay。如果master設(shè)置了yes來禁止tcp nodelay設(shè)置,在把數(shù)據(jù)復(fù)制給slave的時(shí)候,會(huì)減少包的數(shù)量和更小的網(wǎng)絡(luò)帶寬。但是這也可能帶來數(shù)據(jù)的延遲。默認(rèn)我們推薦更小的延遲,但是在數(shù)據(jù)量傳輸很大的場(chǎng)景下,建議選擇yes。 repl-disable-tcp-nodelay no#復(fù)制緩沖區(qū)大小,這是一個(gè)環(huán)形復(fù)制緩沖區(qū),用來保存最新復(fù)制的命令。這樣在slave離線的時(shí)候,不需要完全復(fù)制master的數(shù)據(jù),如果可以執(zhí)行部分同步,只需要把緩沖區(qū)的部分?jǐn)?shù)據(jù)復(fù)制給slave,就能恢復(fù)正常復(fù)制狀態(tài)。緩沖區(qū)的大小越大,slave離線的時(shí)間可以更長,復(fù)制緩沖區(qū)只有在有slave連接的時(shí)候才分配內(nèi)存。沒有slave的一段時(shí)間,內(nèi)存會(huì)被釋放出來,默認(rèn)1m。 # repl-backlog-size 5mb#master沒有slave一段時(shí)間會(huì)釋放復(fù)制緩沖區(qū)的內(nèi)存,repl-backlog-ttl用來設(shè)置該時(shí)間長度。單位為秒。 # repl-backlog-ttl 3600#當(dāng)master不可用,Sentinel會(huì)根據(jù)slave的優(yōu)先級(jí)選舉一個(gè)master。最低的優(yōu)先級(jí)的slave,當(dāng)選master。而配置成0,永遠(yuǎn)不會(huì)被選舉。 slave-priority 100#redis提供了可以讓master停止寫入的方式,如果配置了min-slaves-to-write,健康的slave的個(gè)數(shù)小于N,mater就禁止寫入。master最少得有多少個(gè)健康的slave存活才能執(zhí)行寫命令。這個(gè)配置雖然不能保證N個(gè)slave都一定能接收到master的寫操作,但是能避免沒有足夠健康的slave的時(shí)候,master不能寫入來避免數(shù)據(jù)丟失。設(shè)置為0是關(guān)閉該功能。 # min-slaves-to-write 3#延遲小于min-slaves-max-lag秒的slave才認(rèn)為是健康的slave。 # min-slaves-max-lag 10

    4)總結(jié)

    Redis目前的復(fù)制是異步的,只保證最終一致性,而不是強(qiáng)一致性(主從數(shù)據(jù)庫的更新還是分先后,先主后從)。要是一致性要求高的應(yīng)用,目前還是讀寫都在主庫上去。

    Redis-Sentinel

    需要對(duì)redis和sentinel的配置文件有rewrite的權(quán)限。

    1)搭建:

    環(huán)境:redis服務(wù)3個(gè)實(shí)例10086、10087、10088;sentinel服務(wù)3個(gè)監(jiān)控:20086、20087、20088

    sentinel是一個(gè)"監(jiān)視器",根據(jù)被監(jiān)視實(shí)例的身份和狀態(tài)來判斷該執(zhí)行何種操作。通過給定的配置文件來發(fā)現(xiàn)主服務(wù)器的,再通過向主服務(wù)器發(fā)送的info信息來發(fā)現(xiàn)該主服務(wù)器的從服務(wù)器。Sentinel 實(shí)際上就是一個(gè)運(yùn)行在 Sentienl 模式下的 Redis 服務(wù)器,所以我們同樣可以使用以下命令來啟動(dòng)一個(gè) Sentinel實(shí)例。運(yùn)行方式如下:

    redis-sentinel /path/to/sentinel.conf

    參數(shù)配置文件:

    port 20086 #默認(rèn)端口26379dir "/tmp"logfile "/var/log/redis/sentinel_20086.log"daemonize yes#格式:sentinel <option_name> <master_name> <option_value>;#該行的意思是:監(jiān)控的master的名字叫做T1(自定義),地址為127.0.0.1:10086,行尾最后的一個(gè)2代表在sentinel集群中,多少個(gè)sentinel認(rèn)為masters死了,才能真正認(rèn)為該master不可用了。 sentinel monitor T1 127.0.0.1 10086 2 #sentinel會(huì)向master發(fā)送心跳PING來確認(rèn)master是否存活,如果master在“一定時(shí)間范圍”內(nèi)不回應(yīng)PONG 或者是回復(fù)了一個(gè)錯(cuò)誤消息,那么這個(gè)sentinel會(huì)主觀地(單方面地)認(rèn)為這個(gè)master已經(jīng)不可用了(subjectively down, 也簡稱為SDOWN)。而這個(gè)down-after-milliseconds就是用來指定這個(gè)“一定時(shí)間范圍”的,單位是毫秒,默認(rèn)30秒。 sentinel down-after-milliseconds T1 15000#failover過期時(shí)間,當(dāng)failover開始后,在此時(shí)間內(nèi)仍然沒有觸發(fā)任何failover操作,當(dāng)前sentinel將會(huì)認(rèn)為此次failoer失敗。默認(rèn)180秒,即3分鐘。 sentinel failover-timeout T1 120000#在發(fā)生failover主備切換時(shí),這個(gè)選項(xiàng)指定了最多可以有多少個(gè)slave同時(shí)對(duì)新的master進(jìn)行同步,這個(gè)數(shù)字越小,完成failover所需的時(shí)間就越長,但是如果這個(gè)數(shù)字越大,就意味著越多的slave因?yàn)閞eplication而不可用。可以通過將這個(gè)值設(shè)為 1 來保證每次只有一個(gè)slave處于不能處理命令請(qǐng)求的狀態(tài)。 sentinel parallel-syncs T1 1#sentinel 連接設(shè)置了密碼的主和從 #sentinel auth-pass <master_name> xxxxx#發(fā)生切換之后執(zhí)行的一個(gè)自定義腳本:如發(fā)郵件、vip切換等 ##sentinel notification-script <master-name> <script-path> ##不會(huì)執(zhí)行,疑問? #sentinel client-reconfig-script <master-name> <script-path> ##這個(gè)會(huì)執(zhí)行

    注意:要是參數(shù)配置的是默認(rèn)值,在sentinel運(yùn)行時(shí)該參數(shù)會(huì)在配置文件文件里被刪除掉,直接不顯示。也可以在運(yùn)行時(shí)用命令SENTINEL SET command動(dòng)態(tài)修改,后面說明。

    很顯然,只使用單個(gè)sentinel進(jìn)程來監(jiān)控redis集群是不可靠的,當(dāng)sentinel進(jìn)程宕掉后(sentinel本身也有單點(diǎn)問題,single-point-of-failure)整個(gè)集群系統(tǒng)將無法按照預(yù)期的方式運(yùn)行。所以有必要將sentinel集群,這樣有幾個(gè)好處:

  • 即使有一些sentinel進(jìn)程宕掉了,依然可以進(jìn)行redis集群的主備切換;
  • 如果只有一個(gè)sentinel進(jìn)程,如果這個(gè)進(jìn)程運(yùn)行出錯(cuò),或者是網(wǎng)絡(luò)堵塞,那么將無法實(shí)現(xiàn)redis集群的主備切換(單點(diǎn)問題);
  • 如果有多個(gè)sentinel,redis的客戶端可以隨意地連接任意一個(gè)sentinel來獲得關(guān)于redis集群中的信息。
  • 本文開啟sentinel集群用了3個(gè)實(shí)例,保證各個(gè)端口和目錄不一致,配置文件如下:
    sentinel_20086.conf :

    port 20086dir "/var/lib/sentinel_20086"logfile "/var/log/redis/sentinel_20086.log"daemonize yessentinel monitor T1 127.0.0.1 10086 2sentinel down-after-milliseconds T1 15000sentinel failover-timeout T1 120000sentinel parallel-syncs T1 1#發(fā)生切換之后執(zhí)行的一個(gè)自定義腳本:如發(fā)郵件、vip切換等 #sentinel notification-script <master-name> <script-path>

    sentinel_20087.conf :

    port 20087dir "/var/lib/sentinel_20087"logfile "/var/log/redis/sentinel_20087.log"daemonize yessentinel monitor T1 127.0.0.1 10086 2sentinel down-after-milliseconds T1 15000sentinel failover-timeout T1 120000sentinel parallel-syncs T1 1#發(fā)生切換之后執(zhí)行的一個(gè)自定義腳本:如發(fā)郵件、vip切換等 #sentinel notification-script <master-name> <script-path>

    sentinel_20088.conf :

    port 20088dir "/var/lib/sentinel_20086"logfile "/var/log/redis/sentinel_20088.log"daemonize yessentinel monitor T1 127.0.0.1 10086 2sentinel down-after-milliseconds T1 15000sentinel failover-timeout T1 120000sentinel parallel-syncs T1 1#發(fā)生切換之后執(zhí)行的一個(gè)自定義腳本:如發(fā)郵件、vip切換等 #sentinel notification-script <master-name> <script-path>

    疑問:這里的參數(shù) sentinel notification-script 好像切換的時(shí)候不會(huì)執(zhí)行,參數(shù)sentinel client-reconfig-script 倒是會(huì)執(zhí)行,可以用這個(gè)參數(shù)來替換上面的參數(shù)。

    啟動(dòng)sentinel:

    root@zhoujinyi:/etc/redis# redis-sentinel /etc/redis/sentinel_20086.conf root@zhoujinyi:/etc/redis# redis-sentinel /etc/redis/sentinel_20087.conf root@zhoujinyi:/etc/redis# redis-sentinel /etc/redis/sentinel_20088.conf

    注意:當(dāng)一個(gè)master配置為需要密碼才能連接時(shí),客戶端和slave在連接時(shí)都需要提供密碼。master通過requirepass設(shè)置自身的密碼,不提供密碼無法連接到這個(gè)master。slave通過masterauth來設(shè)置訪問master時(shí)的密碼。客戶端需要auth提供密碼,但是當(dāng)使用了sentinel時(shí),由于一個(gè)master可能會(huì)變成一個(gè)slave,一個(gè)slave也可能會(huì)變成master,所以需要同時(shí)設(shè)置上述兩個(gè)配置項(xiàng),并且sentinel需要連接master和slave,需要設(shè)置參數(shù):sentinel auth-pass <master_name> xxxxx。

    啟動(dòng)后各個(gè)sentinel的日志信息如下:

    3462:X 08 Jun 18:07:54.820 # Sentinel runid is b44bb512b3b756c97f48aff1dc37b54a30659ee9 3462:X 08 Jun 18:07:54.820 # +monitor master T1 127.0.0.1 10086 quorum 2 #主加入監(jiān)控 3462:X 08 Jun 18:07:54.823 * +slave slave 127.0.0.1:10087 127.0.0.1 10087 @ T1 127.0.0.1 10086 #檢測(cè)到一個(gè)slave并添加進(jìn)slave列表 3462:X 08 Jun 18:07:54.823 * +slave slave 127.0.0.1:10088 127.0.0.1 10088 @ T1 127.0.0.1 10086 #檢測(cè)到一個(gè)slave并添加進(jìn)slave列表 3462:X 08 Jun 18:07:59.515 * +sentinel sentinel 127.0.0.1:20087 127.0.0.1 20087 @ T1 127.0.0.1 10086 #增加了一個(gè)sentinel 3462:X 08 Jun 18:08:01.820 * +sentinel sentinel 127.0.0.1:20088 127.0.0.1 20088 @ T1 127.0.0.1 10086 #增加了一個(gè)sentinel

    關(guān)于更多的信息見:

    +reset-master <instance details> -- 當(dāng)master被重置時(shí).+slave <instance details> -- 當(dāng)檢測(cè)到一個(gè)slave并添加進(jìn)slave列表時(shí).+failover-state-reconf-slaves <instance details> -- Failover狀態(tài)變?yōu)閞econf-slaves狀態(tài)時(shí)+failover-detected <instance details> -- 當(dāng)failover發(fā)生時(shí)+slave-reconf-sent <instance details> -- sentinel發(fā)送SLAVEOF命令把它重新配置時(shí)+slave-reconf-inprog <instance details> -- slave被重新配置為另外一個(gè)master的slave,但數(shù)據(jù)復(fù)制還未發(fā)生時(shí)。+slave-reconf-done <instance details> -- slave被重新配置為另外一個(gè)master的slave并且數(shù)據(jù)復(fù)制已經(jīng)與master同步時(shí)。-dup-sentinel <instance details> -- 刪除指定master上的冗余sentinel時(shí) (當(dāng)一個(gè)sentinel重新啟動(dòng)時(shí),可能會(huì)發(fā)生這個(gè)事件).+sentinel <instance details> -- 當(dāng)master增加了一個(gè)sentinel時(shí)。+sdown <instance details> -- 進(jìn)入SDOWN狀態(tài)時(shí);-sdown <instance details> -- 離開SDOWN狀態(tài)時(shí)。+odown <instance details> -- 進(jìn)入ODOWN狀態(tài)時(shí)。-odown <instance details> -- 離開ODOWN狀態(tài)時(shí)。+new-epoch <instance details> -- 當(dāng)前配置版本被更新時(shí)。+try-failover <instance details> -- 達(dá)到failover條件,正等待其他sentinel的選舉。+elected-leader <instance details> -- 被選舉為去執(zhí)行failover的時(shí)候。+failover-state-select-slave <instance details> -- 開始要選擇一個(gè)slave當(dāng)選新master時(shí)。no-good-slave <instance details> -- 沒有合適的slave來擔(dān)當(dāng)新masterselected-slave <instance details> -- 找到了一個(gè)適合的slave來擔(dān)當(dāng)新masterfailover-state-send-slaveof-noone <instance details> -- 當(dāng)把選擇為新master的slave的身份進(jìn)行切換的時(shí)候。failover-end-for-timeout <instance details> -- failover由于超時(shí)而失敗時(shí)。failover-end <instance details> -- failover成功完成時(shí)。switch-master <master name> <oldip> <oldport> <newip> <newport> -- 當(dāng)master的地址發(fā)生變化時(shí)。通常這是客戶端最感興趣的消息了。+tilt -- 進(jìn)入Tilt模式。-tilt -- 退出Tilt模式。

    2)原理

    • ①sentinel集群通過給定的配置文件發(fā)現(xiàn)master,啟動(dòng)時(shí)會(huì)監(jiān)控master。通過向master發(fā)送info信息獲得該服務(wù)器下面的所有從服務(wù)器。
    • ②sentinel集群通過命令連接向被監(jiān)視的主從服務(wù)器發(fā)送hello信息(每秒一次),該信息包括sentinel本身的ip、端口、id等內(nèi)容,以此來向其他sentinel宣告自己的存在。
    • ③sentinel集群通過訂閱連接接收其他sentinel發(fā)送的hello信息,以此來發(fā)現(xiàn)監(jiān)視同一個(gè)主服務(wù)器的其他sentinel;集群之間會(huì)互相創(chuàng)建命令連接用于通信,因?yàn)橐呀?jīng)有主從服務(wù)器作為發(fā)送和接收hello信息的中介,sentinel之間不會(huì)創(chuàng)建訂閱連接。
    • ④sentinel集群使用ping命令來檢測(cè)實(shí)例的狀態(tài),如果在指定的時(shí)間內(nèi)(down-after-milliseconds)沒有回復(fù)或則返回錯(cuò)誤的回復(fù),那么該實(shí)例被判為下線。
    • ⑤當(dāng)failover主備切換被觸發(fā)后,failover并不會(huì)馬上進(jìn)行,還需要sentinel中的大多數(shù)sentinel授權(quán)后才可以進(jìn)行failover,即進(jìn)行failover的sentinel會(huì)去獲得指定quorum個(gè)的sentinel的授權(quán),成功后進(jìn)入ODOWN狀態(tài)。如在5個(gè)sentinel中配置了2個(gè)quorum,等到2個(gè)sentinel認(rèn)為master死了就執(zhí)行failover。
    • ⑥sentinel向選為master的slave發(fā)送SLAVEOF NO ONE命令,選擇slave的條件是sentinel首先會(huì)根據(jù)slaves的優(yōu)先級(jí)來進(jìn)行排序,優(yōu)先級(jí)越小排名越靠前。如果優(yōu)先級(jí)相同,則查看復(fù)制的下標(biāo),哪個(gè)從master接收的復(fù)制數(shù)據(jù)多,哪個(gè)就靠前。如果優(yōu)先級(jí)和下標(biāo)都相同,就選擇進(jìn)程ID較小的。
    • ⑦sentinel被授權(quán)后,它將會(huì)獲得宕掉的master的一份最新配置版本號(hào)(config-epoch),當(dāng)failover執(zhí)行結(jié)束以后,這個(gè)版本號(hào)將會(huì)被用于最新的配置,通過廣播形式通知其它sentinel,其它的sentinel則更新對(duì)應(yīng)master的配置。

    ①到③是自動(dòng)發(fā)現(xiàn)機(jī)制:

    • 以10秒一次的頻率,向被監(jiān)視的master發(fā)送info命令,根據(jù)回復(fù)獲取master當(dāng)前信息。
    • 以1秒一次的頻率,向所有redis服務(wù)器、包含sentinel在內(nèi)發(fā)送PING命令,通過回復(fù)判斷服務(wù)器是否在線。
    • 以2秒一次的頻率,通過向所有被監(jiān)視的master,slave服務(wù)器發(fā)送當(dāng)前sentinel,master信息的消息。

    ④是檢測(cè)機(jī)制,⑤和⑥是failover機(jī)制,⑦是更新配置機(jī)制。

    注意:因?yàn)閞edis采用的是異步復(fù)制,沒有辦法避免數(shù)據(jù)的丟失。但可以通過以下配置來使得數(shù)據(jù)不會(huì)丟失:min-slaves-to-write 1 、 min-slaves-max-lag 10。一個(gè)redis無論是master還是slave,都必須在配置中指定一個(gè)slave優(yōu)先級(jí)。要注意到master也是有可能通過failover變成slave的。如果一個(gè)redis的slave優(yōu)先級(jí)配置為0,那么它將永遠(yuǎn)不會(huì)被選為master,但是它依然會(huì)從master哪里復(fù)制數(shù)據(jù)。

    3)運(yùn)行測(cè)試

    上面已經(jīng)搭好了一個(gè)簡單的測(cè)試環(huán)境:redis服務(wù)3個(gè)實(shí)例10086(M)、10087(S)、10088(S);sentinel服務(wù)3個(gè)監(jiān)控:20086、20087、20088
    現(xiàn)在進(jìn)行一個(gè)故障轉(zhuǎn)移的操作:0點(diǎn)30分14秒kill掉10086,Sentinel日志信息:

    3466:X 09 Jun 00:30:29.067 # +sdown master T1 127.0.0.1 10086 ##進(jìn)入主觀不可用(SDOWN) 3466:X 09 Jun 00:30:29.169 # +odown master T1 127.0.0.1 10086 #quorum 2/2 ##投票好了,達(dá)到了quorum,進(jìn)入客觀不可用(ODOWN) 3466:X 09 Jun 00:30:29.169 # +new-epoch 1 ##當(dāng)前配置版本被更新 3466:X 09 Jun 00:30:29.169 # +try-failover master T1 127.0.0.1 10086 ##達(dá)到failover條件,正等待其他sentinel的選舉 3466:X 09 Jun 00:30:29.179 # +vote-for-leader e106f1eaffdaa10babef3f5858a7cb8d05ffe9ea 1 ##選舉 3466:X 09 Jun 00:30:29.183 # 127.0.0.1:20088 voted for e106f1eaffdaa10babef3f5858a7cb8d05ffe9ea 1 ##選舉 3466:X 09 Jun 00:30:29.184 # 127.0.0.1:20086 voted for e106f1eaffdaa10babef3f5858a7cb8d05ffe9ea 1 ##選舉 3466:X 09 Jun 00:30:29.241 # +elected-leader master T1 127.0.0.1 10086 ##執(zhí)行failover 3466:X 09 Jun 00:30:29.242 # +failover-state-select-slave master T1 127.0.0.1 10086 ##開始要選擇一個(gè)slave當(dāng)選新master 3466:X 09 Jun 00:30:29.344 # +selected-slave slave 127.0.0.1:10088 127.0.0.1 10088 @ T1 127.0.0.1 10086 ##找到了一個(gè)適合的slave來擔(dān)當(dāng)新master 3466:X 09 Jun 00:30:29.344 * +failover-state-send-slaveof-noone slave 127.0.0.1:10088 127.0.0.1 10088 @ T1 127.0.0.1 10086 ##當(dāng)把選擇為新master的slave的身份進(jìn)行切換 3466:X 09 Jun 00:30:29.447 * +failover-state-wait-promotion slave 127.0.0.1:10088 127.0.0.1 10088 @ T1 127.0.0.1 10086 3466:X 09 Jun 00:30:30.206 # +promoted-slave slave 127.0.0.1:10088 127.0.0.1 10088 @ T1 127.0.0.1 10086 3466:X 09 Jun 00:30:30.207 # +failover-state-reconf-slaves master T1 127.0.0.1 10086 ##Failover狀態(tài)變?yōu)閞econf-slaves 3466:X 09 Jun 00:30:30.273 * +slave-reconf-sent slave 127.0.0.1:10087 127.0.0.1 10087 @ T1 127.0.0.1 10086 ##sentinel發(fā)送SLAVEOF命令把它重新配置,重新配置到新主 3466:X 09 Jun 00:30:31.250 * +slave-reconf-inprog slave 127.0.0.1:10087 127.0.0.1 10087 @ T1 127.0.0.1 10086 ##slave被重新配置為另外一個(gè)master的slave,但數(shù)據(jù)復(fù)制還未發(fā)生 3466:X 09 Jun 00:30:31.251 * +slave-reconf-done slave 127.0.0.1:10087 127.0.0.1 10087 @ T1 127.0.0.1 10086 ##slave被重新配置為另外一個(gè)master的slave并且數(shù)據(jù)復(fù)制已經(jīng)與master同步 3466:X 09 Jun 00:30:31.340 # -odown master T1 127.0.0.1 10086 ##離開客觀不可用(ODOWN) 3466:X 09 Jun 00:30:31.340 # +failover-end master T1 127.0.0.1 10086 ##failover成功完成 3466:X 09 Jun 00:30:31.341 # +switch-master T1 127.0.0.1 10086 127.0.0.1 10088 ##master的地址發(fā)生變化 3466:X 09 Jun 00:30:31.341 * +slave slave 127.0.0.1:10087 127.0.0.1 10087 @ T1 127.0.0.1 10088 ##檢測(cè)到一個(gè)slave并添加進(jìn)slave列表 3466:X 09 Jun 00:30:31.351 * +slave slave 127.0.0.1:10086 127.0.0.1 10086 @ T1 127.0.0.1 10088 3466:X 09 Jun 00:30:46.362 # +sdown slave 127.0.0.1:10086 127.0.0.1 10086 @ T1 127.0.0.1 10088 ##原主進(jìn)入主觀不可用狀態(tài)

    通過日志信息看到,15秒(down-after-milliseconds)之后進(jìn)行了failvoer操作,最后操作成功,10088變成了新主,可以通過info sentinel和sentinel maters查看主的信息。把原主開起來,日志信息:

    3466:X 09 Jun 01:00:35.306 # -sdown slave 127.0.0.1:10086 127.0.0.1 10086 @ T1 127.0.0.1 10088 ##離開主觀不可用狀態(tài) 3466:X 09 Jun 01:00:45.249 * +convert-to-slave slave 127.0.0.1:10086 127.0.0.1 10086 @ T1 127.0.0.1 10088 ## 檢測(cè)到一個(gè)slave并添加進(jìn)slave列表

    通過日志看到,原主起來之后變成了從。這里可以發(fā)現(xiàn)在redis配置文件(可寫權(quán)限)的最后被添加了:

    # Generated by CONFIG REWRITE slaveof 127.0.0.1 10088

    在新主上操作,可以同步復(fù)制到從庫:

    root@zhoujinyi:~# redis-cli -p 10088 127.0.0.1:10088> set dxy dxy OK 127.0.0.1:10088> get dxy "dxy" 127.0.0.1:10088> root@zhoujinyi:~# redis-cli -p 10086 127.0.0.1:10086> get dxy "dxy" 127.0.0.1:10086> root@zhoujinyi:~# redis-cli -p 10087 127.0.0.1:10087> get dxy "dxy"

    上面測(cè)試說明sentinel自動(dòng)failover成功。要是kill掉一個(gè)sentinel實(shí)例會(huì)怎么樣?可以看日志:

    3466:X 09 Jun 01:14:51.039 # +sdown sentinel 127.0.0.1:20088 127.0.0.1 20088 @ T1 127.0.0.1 10087 ##進(jìn)入主觀不可用 3466:X 09 Jun 01:15:32.610 # -sdown sentinel 127.0.0.1:20088 127.0.0.1 20088 @ T1 127.0.0.1 10087 ##進(jìn)入客觀不可用 3466:X 09 Jun 01:15:34.497 * -dup-sentinel master T1 127.0.0.1 10087 #duplicate of 127.0.0.1:20088 or a79f189986ab9d3940de48099e18a99abef4d595 ##刪除指定master上的冗余sentinel時(shí) (當(dāng)一個(gè)sentinel重新啟動(dòng)時(shí),可能會(huì)發(fā)生這個(gè)事件) 3466:X 09 Jun 01:15:34.498 * +sentinel sentinel 127.0.0.1:20088 127.0.0.1 20088 @ T1 127.0.0.1 10087 ##檢測(cè)到一個(gè)sentinel,并進(jìn)入列表

    說明sentinel實(shí)例也被其他sentinel監(jiān)視(上面介紹了各個(gè)sentinel相互通信),防止sentinel單點(diǎn)故障。通過日志看到這么多信息,這里需要注意下下面的概念:

    ① Leader選舉:

    其實(shí)在sentinels故障轉(zhuǎn)移中,仍然需要一個(gè)“Leader”來調(diào)度整個(gè)過程:master的選舉以及slave的重配置和同步。當(dāng)集群中有多個(gè)sentinel實(shí)例時(shí),如何選舉其中一個(gè)sentinel為leader呢?

    在配置文件中“can-failover”“quorum”參數(shù),以及“is-master-down-by-addr”指令配合來完成整個(gè)過程。

  • “can-failover”用來表明當(dāng)前sentinel是否可以參與“failover”過程,如果為“YES”則表明它將有能力參與“Leader”的選舉,否則它將作為“Observer”,observer參與leader選舉投票但不能被選舉;

  • “quorum”不僅用來控制master ODOWN狀態(tài)確認(rèn),同時(shí)還用來選舉leader時(shí)最小“贊同票”數(shù);

  • “is-master-down-by-addr”,在上文中以及提到,它可以用來檢測(cè)“ip + port”的master是否已經(jīng)處于SDOWN狀態(tài),不過此指令不僅能夠獲得master是否處于SDOWN,同時(shí)它還額外的返回當(dāng)前sentinel本地“投票選舉”的Leader信息(runid);

    每個(gè)sentinel實(shí)例都持有其他的sentinels信息,在Leader選舉過程中(當(dāng)為leader的sentinel實(shí)例失效時(shí),有可能master server并沒失效,注意分開理解),sentinel實(shí)例將從所有的sentinels集合中去除“can-failover = no”和狀態(tài)為SDOWN的sentinels,在剩余的sentinels列表中按照runid按照“字典”順序排序后,取出runid最小的sentinel實(shí)例,并將它“投票選舉”為Leader,并在其他sentinel發(fā)送的“is-master-down-by-addr”指令時(shí)將推選的runid追加到響應(yīng)中。每個(gè)sentinel實(shí)例都會(huì)檢測(cè)“is-master-down-by-addr”的響應(yīng)結(jié)果,如果“投票選舉”的leader為自己,且狀態(tài)正常的sentinels實(shí)例中,“贊同者”的自己的sentinel個(gè)數(shù)不小于(>=) 50% + 1,且不小與,那么此sentinel就會(huì)認(rèn)為選舉成功且leader為自己。

    在sentinel.conf文件中,我們期望有足夠多的sentinel實(shí)例配置“can-failover yes”,這樣能夠確保當(dāng)leader失效時(shí),能夠選舉某個(gè)sentinel為leader,以便進(jìn)行failover。如果leader無法產(chǎn)生,比如較少的sentinels實(shí)例有效,那么failover過程將無法繼續(xù)。

  • ② failover過程:

    在Leader觸發(fā)failover之前,首先wait數(shù)秒(隨即0~5),以便讓其他sentinel實(shí)例準(zhǔn)備和調(diào)整(有可能多個(gè)leader??),如果一切正常,那么leader就需要開始將一個(gè)salve提升為master,此slave必須為狀態(tài)良好(不能處于SDOWN/ODOWN狀態(tài))且權(quán)重值最低(redis.conf中)的,當(dāng)master身份被確認(rèn)后,開始failover

  • “+failover-triggered”: Leader開始進(jìn)行failover,此后緊跟著“+failover-state-wait-start”,wait數(shù)秒。

  • “+failover-state-select-slave”: Leader開始查找合適的slave

  • “+selected-slave”: 已經(jīng)找到合適的slave

  • “+failover-state-sen-slaveof-noone”: Leader向slave發(fā)送“slaveof no one”指令,此時(shí)slave已經(jīng)完成角色轉(zhuǎn)換,此slave即為master

  • “+failover-state-wait-promotition”: 等待其他sentinel確認(rèn)slave

  • “+promoted-slave”:確認(rèn)成功

  • “+failover-state-reconf-slaves”: 開始對(duì)slaves進(jìn)行reconfig操作。

  • “+slave-reconf-sent”:向指定的slave發(fā)送“slaveof”指令,告知此slave跟隨新的master

  • “+slave-reconf-inprog”: 此slave正在執(zhí)行slaveof + SYNC過程,如過slave收到“+slave-reconf-sent”之后將會(huì)執(zhí)行slaveof操作。

  • “+slave-reconf-done”: 此slave同步完成,此后leader可以繼續(xù)下一個(gè)slave的reconfig操作。循環(huán)G)

  • “+failover-end”: 故障轉(zhuǎn)移結(jié)束

  • “+switch-master”:故障轉(zhuǎn)移成功后,各個(gè)sentinel實(shí)例開始監(jiān)控新的master。

  • 4)命令查看、修改

    查看:

    ①:info命令

    127.0.0.1:20086> info # Server redis_version:3.0.0 #版本號(hào) redis_git_sha1:00000000 redis_git_dirty:0 redis_build_id:e7768317ba5bdca5 redis_mode:sentinel #開啟模式 os:Linux 3.16.0-71-generic x86_64 #系統(tǒng)位數(shù) arch_bits:64 multiplexing_api:epoll gcc_version:4.8.2 process_id:2767 #線程ID run_id:319d8c58b9bf26c26ca040b53bdc0764a543648b tcp_port:20086 #端口 uptime_in_seconds:923 #允許時(shí)間 uptime_in_days:0 hz:11 lru_clock:6041117 config_file:/etc/redis/sentinel_20086.conf #配置文件# Sentinel sentinel_masters:1 sentinel_tilt:0 sentinel_running_scripts:0 sentinel_scripts_queue_length:0 master0:name=T1,status=ok,address=127.0.0.1:10087,slaves=2,sentinels=3 #主name,主ip,多少個(gè)slave,多少個(gè)sentinel

    也可以單個(gè)顯示:info server、info sentinel。

    ②:sentinel masters,顯示被監(jiān)控的所有master以及它們的狀態(tài)。要是有多個(gè)master就顯示多個(gè)(復(fù)用,監(jiān)控多個(gè)redis,即一個(gè)配置文件寫多個(gè)),例子就1個(gè)master

    127.0.0.1:20086> SENTINEL masters 1) 1) "name" #master name2) "T1"3) "ip" #master ip4) "127.0.0.1"5) "port" #master port6) "10087"7) "runid"8) "508e7de9f5aa4fdb70126d62a54392fbefc0b11b"9) "flags"10) "master"11) "pending-commands"12) "0"13) "last-ping-sent"14) "0"15) "last-ok-ping-reply"16) "261"17) "last-ping-reply"18) "261"19) "down-after-milliseconds" #ping的響應(yīng)時(shí)間20) "15000"21) "info-refresh"22) "620"23) "role-reported"24) "master"25) "role-reported-time"26) "1205058"27) "config-epoch" #配置文件版本號(hào)28) "2"29) "num-slaves" #從的數(shù)量30) "2"31) "num-other-sentinels" #除本身外還有多少個(gè)sentinel32) "2"33) "quorum" #投票數(shù)量34) "2"35) "failover-timeout" #failover超時(shí)時(shí)間36) "120000"37) "parallel-syncs" #多少個(gè)從同步38) "1"

    ③:sentinel master <master_name>,顯示指定master的信息和狀態(tài)。

    127.0.0.1:20086> sentinel master T11) "name"2) "T1"3) "ip"4) "127.0.0.1"5) "port"6) "10087"7) "runid"8) "508e7de9f5aa4fdb70126d62a54392fbefc0b11b"9) "flags" 10) "master" 11) "pending-commands" 12) "0" 13) "last-ping-sent" 14) "0" 15) "last-ok-ping-reply" 16) "909" 17) "last-ping-reply" 18) "909" 19) "down-after-milliseconds" 20) "15000" 21) "info-refresh" 22) "5820" 23) "role-reported" 24) "master" 25) "role-reported-time" 26) "1501345" 27) "config-epoch" 28) "2" 29) "num-slaves" 30) "2" 31) "num-other-sentinels" 32) "2" 33) "quorum" 34) "2" 35) "failover-timeout" 36) "120000" 37) "parallel-syncs" 38) "1"

    ④:sentinel slaves <master_name>,顯示指定master的所有slave以及它們的狀態(tài)。

    127.0.0.1:20086> sentinel slaves T1 1) 1) "name"2) "127.0.0.1:10088"3) "ip"4) "127.0.0.1"5) "port"6) "10088"7) "runid"8) "380a4d9e32aefd3a00c7a64ba8bce451643044f1"9) "flags"10) "slave"11) "pending-commands"12) "0"13) "last-ping-sent"14) "0"15) "last-ok-ping-reply"16) "15"17) "last-ping-reply"18) "15"19) "down-after-milliseconds"20) "15000"21) "info-refresh"22) "7558"23) "role-reported"24) "slave"25) "role-reported-time"26) "1934978"27) "master-link-down-time"28) "0"29) "master-link-status"30) "ok"31) "master-host"32) "127.0.0.1"33) "master-port"34) "10087"35) "slave-priority"36) "100"37) "slave-repl-offset"38) "361068" 2) 1) "name"2) "127.0.0.1:10086"3) "ip"4) "127.0.0.1"5) "port"6) "10086"7) "runid"8) "9babf78ee2b420d2671b12f93b68c4d19a5edf08"9) "flags"10) "slave"11) "pending-commands"12) "0"13) "last-ping-sent"14) "0"15) "last-ok-ping-reply"16) "15"17) "last-ping-reply"18) "15"19) "down-after-milliseconds"20) "15000"21) "info-refresh"22) "7558"23) "role-reported"24) "slave"25) "role-reported-time"26) "1934978"27) "master-link-down-time"28) "0"29) "master-link-status"30) "ok"31) "master-host"32) "127.0.0.1"33) "master-port"34) "10087"35) "slave-priority"36) "100"37) "slave-repl-offset"38) "361068"

    ⑤:sentinel get-master-addr-by-name <master_name>,返回指定master的ip和端口,如果正在進(jìn)行failover或者failover已經(jīng)完成,將會(huì)顯示被提升為master的slave的ip和端口。

    27.0.0.1:20086> sentinel get-master-addr-by-name T1 1) "127.0.0.1" 2) "10087"

    ⑥:sentinel reset :重置名字匹配該正則表達(dá)式的所有的master的狀態(tài)信息,清除其之前的狀態(tài)信息,以及slaves信息。比如刪除一個(gè)slave或則sentinel時(shí)候,先關(guān)閉停止想要?jiǎng)h除的進(jìn)程,再執(zhí)行:

    sentinel reset *

    ⑦:sentinel failover <master_name> 強(qiáng)制sentinel執(zhí)行failover,并且不需要得到其他sentinel的同意。但是failover后會(huì)將最新的配置發(fā)送給其他sentinel。

    127.0.0.1:20086> sentinel failover T1 OK 127.0.0.1:20086> sentinel get-master-addr-by-name T1 1) "127.0.0.1" 2) "10088" #主被切換了

    ⑧:查看其他sentinel信息

    sentinel sentinels T1

    ⑨:檢查sentinel監(jiān)控是否正確

    sentinel ckquorum T1

    ⑩:配置文件丟失,重寫配置文件

    sentinel flushconfig

    修改:包括參數(shù)

    ①:sentinel monitor <master_mname> ,監(jiān)控一個(gè)新的redis master(這時(shí)通過sentinel masters可以看到多個(gè))

    127.0.0.1:20086> SENTINEL MONITOR T2 127.0.0.1 10089 2 OK

    ②:sentinel remove <master_name> 命令sentinel放棄對(duì)某個(gè)master的監(jiān)聽。刪掉上一個(gè)加的:

    127.0.0.1:20086> sentinel remove T2 OK

    ③:sentinel set <master_name> 這個(gè)命令很像Redis的CONFIG SET命令,用來改變指定master的配置。支持多個(gè)。

    127.0.0.1:20086> sentinel masters 1) ...37) "parallel-syncs"38) "1" 127.0.0.1:20086> sentinel set T1 parallel-syncs 2 #格式 OK 127.0.0.1:20086> sentinel masters 1) ...37) "parallel-syncs"38) "2"

    注意:只要是配置文件中存在的配置項(xiàng),都可以用SENTINEL SET命令來設(shè)置。這個(gè)還可以用來設(shè)置master的屬性,比如說quorum(票數(shù)),而不需要先刪除master,再重新添加master。

    5) 增加或刪除Sentinel

    增加一個(gè)sentinel很簡單,直接配置好參數(shù)開啟一個(gè)sentinel即可。添加時(shí)最好一個(gè)接著一個(gè)添加,這樣可以預(yù)防網(wǎng)絡(luò)隔離帶來的問題,可以每個(gè)30秒添加一個(gè)sentinel。通過SENTINEL MASTER mastername(T1)中的num-other-sentinels來查看是否成功添加sentinel。刪除一個(gè)sentinel稍微復(fù)雜一點(diǎn),sentinel永遠(yuǎn)不會(huì)刪除一個(gè)已經(jīng)存在過的sentinel,即使它已經(jīng)與組織失去聯(lián)系。遵循如下步驟:

  • 停止所要?jiǎng)h除的sentinel

  • 發(fā)送一個(gè)SENTINEL RESET * 命令給所有其它的sentinel實(shí)例,如果你想要重置指定master上面的sentinel,只需要把*號(hào)改為特定的名字,注意,需要一個(gè)接一個(gè)發(fā),每次發(fā)送的間隔不低于30秒。

  • 檢查一下所有的sentinels是否都有一致的當(dāng)前sentinel數(shù)。使用SENTINEL MASTER mastername 來查詢。

  • 首先 kill 掉一個(gè)sentinel127.0.0.1:20086> sentinel master T11) "name"2) "T1"3) "ip"4) "127.0.0.1"5) "port"6) "10088"... 31) "num-other-sentinels" 32) "2" ... 127.0.0.1:20086> sentinel reset T1 #重新導(dǎo)入或則執(zhí)行下面的 (integer) 1 127.0.0.1:20086> sentinel reset * #因?yàn)橹挥斜O(jiān)視一個(gè)主,所以和上面一致 (integer) 1 127.0.0.1:20086> sentinel masters 1) 1) "name"2) "T1"3) "ip"4) "127.0.0.1"5) "port"6) "10088" ... ...31) "num-other-sentinels" #sentinel slave的數(shù)量32) "1" ...

    6)刪除舊master或者不可達(dá)slave

    要永久地刪除掉一個(gè)slave(有可能它曾經(jīng)是個(gè)master),你只需要發(fā)送一個(gè)SENTINEL RESET master命令給所有的sentinels,它們將會(huì)更新列表里能夠正確地復(fù)制master數(shù)據(jù)的slave。 遵循如下步驟:

  • 停止所要?jiǎng)h除的redis slave。

  • 發(fā)送一個(gè)SENTINEL RESET * 命令給所有其它的sentinel實(shí)例,如果你想要重置指定master上面的slave,只需要把*號(hào)改為特定的名字。

  • 檢查一下所有的sentinels是否都有一致的當(dāng)前sentinel數(shù)。使用SENTINEL MASTER mastername 來查詢。

  • 首先 kill 掉一個(gè)slave127.0.0.1:20086> sentinel masters 1) 1) "name"2) "T1"3) "ip"4) "127.0.0.1"5) "port"6) "10088" ...29) "num-slaves" #多少個(gè)slave30) "2" ... 127.0.0.1:20086> sentinel reset T1 #重新導(dǎo)入或則執(zhí)行下面的 (integer) 1 127.0.0.1:20086> sentinel reset * #和上面一致 (integer) 1 127.0.0.1:20086> sentinel masters 1) 1) "name"2) "T1"3) "ip"4) "127.0.0.1"5) "port"6) "10088" ...29) "num-slaves" #多少個(gè)slave30) "1" ...

    注意:要是再次開啟關(guān)閉掉的redis slave會(huì)繼續(xù)當(dāng)成一個(gè)slave,若要徹底關(guān)閉slave,則需要修改關(guān)閉掉的redis配置文件中最后的:

    # Generated by CONFIG REWRITE slaveof 127.0.0.1 10088 #關(guān)閉改參數(shù)

    7)總結(jié)

    Redis-Sentinel是Redis官方推薦的高可用性(HA) 解決方案,Redis-sentinel本身也是一個(gè)獨(dú)立運(yùn)行的進(jìn)程,它能監(jiān)控多個(gè)master-slave集群,發(fā)現(xiàn)master宕機(jī)后能進(jìn)行自動(dòng)切換。Sentinel可以監(jiān)視任意多個(gè)主服務(wù)器(復(fù)用),以及主服務(wù)器屬下的從服務(wù)器,并在被監(jiān)視的主服務(wù)器下線時(shí),自動(dòng)執(zhí)行故障轉(zhuǎn)移操作。

    為了防止sentinel的單點(diǎn)故障,可以對(duì)sentinel進(jìn)行集群化,創(chuàng)建多個(gè)sentinel。

    總結(jié)

    以上是生活随笔為你收集整理的Redis 复制、Sentinel的搭建和原理说明的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

    国产中文在线播放 | 天天玩天天干天天操 | 久久激情视频 久久 | 99在线高清视频在线播放 | 亚洲另类久久 | 日韩网页 | 亚洲人成精品久久久久 | 国产vs久久 | 亚洲精品乱码久久久久久蜜桃欧美 | 日p视频| 五月天激情视频在线观看 | 99久久精品国产欧美主题曲 | 五月天堂网 | 9999免费视频 | 九九久久国产 | 亚洲精品在线观看网站 | 久久色在线观看 | av亚洲产国偷v产偷v自拍小说 | 91禁在线观看| 国产 欧美 在线 | 亚在线播放中文视频 | 视频国产 | 成人午夜网 | 国产精品久久在线 | 黄色国产高清 | 欧美一区日韩精品 | 亚洲区视频在线观看 | 91九色精品| 97色婷婷成人综合在线观看 | 久久综合导航 | 91免费网 | 97人人人| 久久亚洲精品电影 | 日日日爽爽爽 | 婷婷六月综合亚洲 | 日本久久精 | 久久国产精彩视频 | 最新久久久 | 国产99久久久精品 | 国产亚洲欧美一区 | 日韩大片在线 | 欧美日韩电影在线播放 | 色综合人人 | 亚洲成人999 | 99国产一区二区三精品乱码 | 国产 一区二区三区 在线 | 免费三级在线 | 国产精品99久久久 | 成人高清av在线 | 国产精品久久久久久久久久久杏吧 | 久久久国产影视 | 日韩在线不卡 | 噜噜色官网 | 精品一区二区在线免费观看 | 免费高清在线视频一区· | 国产美女在线精品免费观看 | 91超级碰碰| 99热这里有精品 | 美女免费视频网站 | 操夜夜操 | 久久久99精品免费观看乱色 | 午夜影院一级片 | 三级视频片 | 久久艹在线观看 | 91精品黄色| 日日碰狠狠添天天爽超碰97久久 | 久久久高清免费视频 | 免费视频黄色 | 国产美女网站视频 | 国产成人高清av | 欧美福利久久 | 久久婷婷激情 | 娇妻呻吟一区二区三区 | 国产最新在线观看 | 一区二区精品视频 | 天天色天天操天天爽 | 在线精品亚洲 | 免费三级黄色片 | 91精品视频播放 | 亚洲成av人片一区二区梦乃 | 精品视频不卡 | 色夜影院| 日韩午夜剧场 | 成人h视频在线 | 四虎国产精品免费 | 国产精品视频最多的网站 | 国产免费一区二区三区最新 | 久久久精品国产免费观看同学 | 亚洲国产免费看 | 1000部18岁以下禁看视频 | 天天久久综合 | 久久久免费电影 | 99精品视频在线 | 久久三级视频 | 少妇bbbb | 中文字幕亚洲五码 | 97色综合| 色瓜 | 久产久精国产品 | 亚洲一级片免费观看 | 九九久久视频 | 国产午夜一区 | 国产精品一区久久久久 | 一区二区三区 亚洲 | 国产激情免费 | 精品在线观看视频 | 99热在线观看 | 最新av网站在线观看 | 99视频偷窥在线精品国自产拍 | 黄色1级毛片 | 摸bbb搡bbb搡bbbb| 99热国产精品 | 超碰最新网址 | 精品久久一级片 | 九九热视频在线 | 午夜精品久久久99热福利 | 日韩精品免费一区二区 | 在线看毛片网站 | 国产精品麻豆果冻传媒在线播放 | 色午夜影院 | 亚洲精品天天 | 久久国产免费看 | 人成午夜视频 | 一级淫片在线观看 | 亚洲无人区小视频 | 欧美日韩精品在线一区二区 | 黄色app网站在线观看 | 国产黄色片久久 | 999成人| 久久电影中文字幕视频 | 欧美巨大 | 天天色天天操综合网 | 91热在线 | 337p日本大胆噜噜噜噜 | 国产色在线观看 | 久久国产女人 | 在线精品观看国产 | 天天天在线综合网 | 五月亚洲综合 | 国内99视频 | 久免费视频 | 九月婷婷色 | 精品一区二区在线播放 | 国产精品男女啪啪 | 黄色免费网站下载 | 久久久这里有精品 | 91日韩在线 | 人人讲 | 亚洲精品乱码久久久久久蜜桃不爽 | 网站免费黄色 | 久久一区二区免费视频 | 日韩av快播电影网 | 国产69精品久久久久99尤 | 久草精品资源 | 正在播放国产精品 | 狠狠干美女 | 日韩中文字幕国产精品 | 亚洲另类xxxx| 999视频网站 | 国产成本人视频在线观看 | 成人在线免费看 | 精品久久久久免费极品大片 | 亚洲激情在线视频 | 亚洲黄色一级视频 | 蜜臀av一区| 久久久国产精品麻豆 | 亚洲干视频在线观看 | 免费激情在线电影 | 国产一区二区三区午夜 | 精品久久久久久亚洲综合网站 | 国产一性一爱一乱一交 | 国产在线欧美日韩 | av大片免费看 | 高清精品久久 | 91久久精品日日躁夜夜躁国产 | 欧美另类69| 免费网址你懂的 | 在线导航福利 | 91一区二区三区久久久久国产乱 | 91视频高清免费 | 国产一级精品视频 | 午夜性福利| 欧美另类视频 | av中文字幕在线观看网站 | 九七视频在线 | 国产真实在线 | 91麻豆精品国产自产在线游戏 | 亚洲综合一区二区精品导航 | 国产区 在线 | 久久官网| 麻豆成人精品 | 国产香蕉视频在线播放 | 国产一区国产二区在线观看 | 97在线看| 天天天干夜夜夜操 | 啪啪动态视频 | 亚洲有 在线| 超碰免费在线公开 | 久久不见久久见免费影院 | 国产成人久久精品77777综合 | 亚洲少妇xxxx | 国产精品高清在线 | 丰满少妇一级片 | 尤物一区二区三区 | 国产精品人成电影在线观看 | 精品在线视频观看 | 五月综合激情 | 日韩小视频网站 | 少妇bbw搡bbbb搡bbbb | 国产中文视 | a级片网站 | 99久热在线精品视频 | 亚洲综合小说电影qvod | av中文字幕在线播放 | 国精产品999国精产品视频 | 丁香六月久久综合狠狠色 | 国产精品18久久久久久久网站 | 精品国产一区二区三区男人吃奶 | 国产亚洲精品福利 | 九色精品 | 香蕉视频在线播放 | 色全色在线资源网 | 欧美一级激情 | 波多野结衣视频在线 | 午夜久久电影网 | 日韩欧美在线不卡 | 永久免费的啪啪网站免费观看浪潮 | 日韩理论片中文字幕 | 91在线精品视频 | 免费久草视频 | 亚洲精品玖玖玖av在线看 | 久久久久久久久久伊人 | 国产精品美女久久久久久久网站 | 欧美va在线观看 | 在线亚洲欧美日韩 | 狠狠激情中文字幕 | 激情婷婷久久 | 欧美日韩在线免费视频 | 蜜臀av网址 | 国产一区二区视频在线 | 久草在线综合网 | 国产精品 日韩 | 中文字幕av在线不卡 | 人人干人人干人人干 | 丁香影院在线 | 久久天堂亚洲 | 四虎在线免费观看视频 | 午夜国产福利在线 | 亚洲无吗天堂 | 99久热精品 | 国内精品久久久久久久久久清纯 | 亚洲日韩欧美视频 | 久久精品国产99 | 欧美日韩亚洲国产一区 | 欧美精品一区二区免费 | 91av视频网| 久久综合九色综合久99 | 视频在线精品 | 婷婷六月中文字幕 | 成人免费视频网站在线观看 | 亚洲精品99久久久久久 | 亚洲精品国产欧美在线观看 | 中文字幕观看av | 亚洲1区 在线 | 在线日韩亚洲 | 国语精品免费视频 | av不卡中文字幕 | 欧美日韩亚洲在线 | 日韩精品最新在线观看 | 人人草天天草 | 久久伊人操 | 成人av资源 | 中文字幕在线一区观看 | 99av在线视频 | 久久 地址| 人人干人人上 | 亚洲精品视频在线 | 婷婷色在线资源 | 91重口视频| 国产.精品.日韩.另类.中文.在线.播放 | 日韩av电影手机在线观看 | 亚洲视频免费 | 国产在线国产 | 伊人伊成久久人综合网小说 | 天天干天天射天天操 | 超碰在线97观看 | 日韩欧美aaa | 国产第页 | 丁香花在线观看免费完整版视频 | 在线色资源 | 久久久久久久久久久久久国产精品 | 91爱爱电影 | 欧美精品乱码久久久久 | 欧美久久久久久久久久 | 五月综合色婷婷 | 欧美日韩视频在线一区 | 久久久免费毛片 | 91黄色小视频 | 亚洲极色 | 国产区精品区 | 久草网站 | 国产专区精品视频 | 超级碰碰碰免费视频 | 婷婷激情影院 | 日日夜夜天天综合 | 亚洲一区二区观看 | 天天干天天碰 | 久久久麻豆 | 日本在线中文在线 | 久久久久久国产精品久久 | 麻豆免费看片 | 久久久久久久网站 | 婷婷五情天综123 | 日韩精品一区二区免费视频 | 国产中出在线观看 | 福利视频入口 | 在线亚洲人成电影网站色www | 国产一级特黄毛片在线毛片 | 特级黄色一级 | 在线观看av小说 | 超碰在线成人 | 国内偷拍精品视频 | 337p欧美| 亚洲成人av片 | 日韩免费av网址 | 欧美日韩在线观看视频 | 日本中文字幕电影在线免费观看 | 日韩精品亚洲专区在线观看 | 欧美少妇18p | 亚洲欧美少妇 | 国产精品久久久久久久av电影 | 国产a免费 | 美女黄网站视频免费 | 免费亚洲精品视频 | 欧美精品日韩 | 久久国产精品99久久人人澡 | 欧美精品三级 | 97色噜噜| 免费看黄色毛片 | 欧美成人一二区 | 久久成人久久 | 亚洲三级精品 | 99久久综合狠狠综合久久 | 国产精品原创av片国产免费 | www.91国产 | 九九免费视频 | www日韩精品 | 在线视频欧美亚洲 | 色综合夜色一区 | 国产.精品.日韩.另类.中文.在线.播放 | 美女精品久久久 | 激情欧美xxxx | 99视频精品全部免费 在线 | 九色精品免费永久在线 | 亚洲精品国产精品国产 | 久久久官网 | 在线成人小视频 | 麻豆精品在线视频 | 中文字幕影视 | 亚州欧美视频 | 亚洲精品综合久久 | 色多视频在线观看 | 色综合五月| 天天干 天天摸 天天操 | 美女视频a美女大全免费下载蜜臀 | 99热在线观看 | 久久久久99精品成人片三人毛片 | 午夜精品一区二区三区视频免费看 | 亚洲国产精品视频在线观看 | 在线日韩视频 | 国产电影一区二区三区四区 | 亚洲欧美日韩精品久久久 | www.夜夜操| 天天射天天拍 | 蜜臀一区二区三区精品免费视频 | 日韩在线观看网站 | 91伊人久久大香线蕉蜜芽人口 | 日日夜夜免费精品 | 东方av免费在线观看 | 亚洲精品看片 | 97av视频在线观看 | 蜜臀久久99精品久久久久久网站 | 国产精品一区二区免费在线观看 | 亚洲综合成人在线 | 成人三级网站在线观看 | 国产香蕉视频 | a久久久久| 久久久久久久久久久久亚洲 | 国产精品系列在线观看 | 成人免费视频网站 | 91免费高清视频 | 中文字幕国产视频 | 国产视频日本 | 97超碰人 | 国产不卡一 | 久久久久综合网 | 国内精品视频一区二区三区八戒 | 在线视频一区二区 | 久久日韩精品 | 亚洲少妇影院 | 国产成人av网 | 91看片淫黄大片在线播放 | 国产精品免费麻豆入口 | 欧美精品亚洲精品 | 日日夜夜噜 | 久久久免费观看视频 | 日韩特级毛片 | 国产色视频网站2 | 精品美女在线视频 | 国产女v资源在线观看 | 超碰免费观看 | 中文日韩在线视频 | 国产手机精品视频 | 成人动态视频 | 一区二区三区免费在线观看视频 | 五月天高清欧美mv | 久久人人爽人人爽 | 日韩一区二区免费播放 | 日韩电影精品 | 激情一区二区三区欧美 | 在线观看久久久久久 | 久久视频免费在线 | www.狠狠插.com| 最近高清中文在线字幕在线观看 | 麻豆精品传媒视频 | 国产又粗又猛又爽又黄的视频免费 | 久久精品国产一区二区三 | 免费日韩一区 | 91最新地址永久入口 | 国产电影黄色av | 国产精品中文久久久久久久 | 日韩成人免费在线观看 | 91尤物国产尤物福利在线播放 | av7777777| 亚洲成人精品久久 | 97在线观视频免费观看 | 91成人网在线 | 亚洲精品色婷婷 | 亚洲国产99 | 国产麻豆精品久久 | 91精品视频在线 | 久久电影色 | 黄在线 | 中文资源在线观看 | 欧美性色xo影院 | 在线观看岛国 | 最近的中文字幕大全免费版 | av丝袜在线| 亚洲区视频在线观看 | 久久久久久久久久久久久9999 | 亚洲国产午夜精品 | 成人97视频一区二区 | www.狠狠操.com | 精品中文字幕在线播放 | 久久午夜精品影院一区 | 黄色小说免费在线观看 | 亚洲精品男人天堂 | 国产成人精品亚洲a | 狠狠做深爱婷婷综合一区 | 91丨九色丨国产在线观看 | 九九在线国产视频 | 久久久久伦理电影 | 国产精品孕妇 | 日韩高清一区 | 成人av影院在线观看 | 99精品视频在线观看免费 | 国产欧美日韩精品一区二区免费 | 中文字幕999 | 久久久免费看视频 | 91视频高清完整版 | 丰满少妇在线观看网站 | 久久男人中文字幕资源站 | 久久久久国产精品免费网站 | 亚洲视频1| 波多野结衣在线播放一区 | 天天干天天综合 | 久久免费美女视频 | 日韩a在线观看 | 91少妇精拍在线播放 | 中文国产字幕 | 国产亚洲精品久久久久久移动网络 | 亚洲成人av在线播放 | 久久综合九色综合欧美就去吻 | 99精品国产在热久久 | 这里只有精品视频在线观看 | 视频在线观看入口黄最新永久免费国产 | 久草免费在线视频 | 九九热有精品 | 高清国产一区 | 日韩av高清在线观看 | 欧美91视频| 国产美女在线观看 | 久久精品国产久精国产 | 免费在线91 | 四虎成人精品在永久免费 | 久久久精品久久日韩一区综合 | 91看片一区二区三区 | 色综合天天视频在线观看 | 狠狠的干 | 国产在线观看h | 天天干天天干天天干 | 日本中文字幕免费观看 | 中文字幕av全部资源www中文字幕在线观看 | 久久国产精品区 | 亚洲一区日韩 | 亚洲一区美女视频在线观看免费 | 成人黄色在线播放 | 天天操操 | 丁香婷婷久久 | 视频福利在线观看 | 欧美日韩成人一区 | 亚洲欧美视频一区二区三区 | 奇米影视777影音先锋 | 欧美一二三区在线观看 | 91tv国产成人福利 | 国产精品久久久久一区二区三区共 | 黄色高清视频在线观看 | 久久精精品 | www.色五月.com | 二区三区中文字幕 | 丁香资源影视免费观看 | 日本久久91| 日日夜夜精品视频天天综合网 | 亚洲国产中文字幕在线观看 | 日韩高清 一区 | 久影院| 国产精品一码二码三码在线 | 欧美电影黄色 | 久久69精品 | 欧美少妇影院 | 91在线在线观看 | 超碰97人| 日韩av在线一区二区 | 日韩在线视频二区 | 久久国产精品99久久久久久老狼 | 日韩中文字幕在线观看 | 黄网站色成年免费观看 | 国产精品一区在线观看 | 五月综合激情 | 激情五月婷婷激情 | 亚洲欧美日本国产 | 人人插人人澡 | 久草在线最新 | 国产亚洲精品日韩在线tv黄 | 中文字幕成人av | 国产啊v在线观看 | 五月天激情综合 | av电影久久 | 久久在线观看视频 | 日日操日日插 | 亚洲黄色在线看 | 日韩精品一区二区三区免费视频观看 | 亚洲成人黄色在线观看 | 精品国产乱码久久久久久1区二区 | 国产精品青青 | 精品久久久久久国产91 | 99久久精品无免国产免费 | 国产精品美女久久久久久免费 | 久草在线免费看视频 | 亚洲成人av在线 | 国产自产在线视频 | bbw av| 精品国产福利在线 | 免费的国产精品 | 国产91在| 99久久日韩精品视频免费在线观看 | 丁香综合av | www.久久色 | 中文字幕文字幕一区二区 | 亚洲三级网 | 一区在线电影 | 欧美激情综合五月 | 永久免费的av电影 | 免费色视频网站 | 91成人免费看 | av丝袜制服 | 亚洲在线黄色 | 久久久久久黄色 | 日韩中文在线电影 | 国产精彩视频一区二区 | 久久久久久久久艹 | 91精品影视| 久久久精品网 | 成人动漫精品一区二区 | 天天艹天天 | 超碰电影在线观看 | 亚洲精品中文字幕视频 | 国产又粗又猛又黄又爽 | 欧美日韩久久久 | 国产精品一区二区在线播放 | 91在线入口 | 91九色免费视频 | 五月婷婷激情综合网 | 国产高清在线看 | 免费视频91蜜桃 | av中文字幕在线观看网站 | 高清在线观看av | 在线免费观看黄色大片 | 久久在线免费观看 | 97超视频| 成人av电影免费在线播放 | 黄色一级大片在线免费看国产一 | 国产片免费在线观看视频 | 日韩69视频 | 国产在线91精品 | 天天操综| 亚洲视频在线看 | 久久精品视频在线 | 亚洲一级电影在线观看 | 久久激情小说 | 人人干人人干人人干 | 精品一二三四在线 | 国产精品成人免费精品自在线观看 | 国产免费久久久久 | 国产精品久久久久久久久久妇女 | 国产精品美女久久久久aⅴ 干干夜夜 | 日韩毛片在线免费观看 | 精品国产一区二区三区蜜臀 | 亚洲jizzjizz日本少妇 | 五月婷婷综合久久 | 在线观看va| 一区二区三区电影 | 麻豆一区二区三区视频 | av综合站| 最新精品视频在线 | 久久这里精品视频 | 最近中文字幕完整高清 | 国产精品原创在线 | 黄色片网站免费 | 久久成人在线 | 在线观看一区 | 中文字幕免费高清在线 | 欧美一区成人 | 午夜精品福利在线 | 日韩av电影手机在线观看 | 182午夜在线观看 | 免费影视大全推荐 | 狠狠久久婷婷 | 中文字幕日本电影 | 手机成人av | 国产91全国探花系列在线播放 | 一区二区丝袜 | 国产精品字幕 | 久久影视精品 | 久久综合久久综合久久综合 | 日本h视频在线观看 | 色综合狠狠干 | 免费观看视频黄 | 国产一区二区在线免费视频 | 美女久久久久久久久久 | 免费热情视频 | 九九免费在线观看视频 | av天天澡天天爽天天av | 国产精品午夜8888 | www.色五月| 91视频xxxx| 欧美精品一区二区三区一线天视频 | 热re99久久精品国产66热 | 亚洲经典精品 | 国产伦理久久精品久久久久_ | 美女性爽视频国产免费app | 黄色99视频 | 成人在线视频免费 | 亚洲精品成人av在线 | 国产精品video | 国产成人一区二 | 色网影音先锋 | 免费人人干 | 国产精品视频久久久 | 国产精品自产拍在线观看桃花 | 精品视频在线视频 | 久久官网| 久草精品在线播放 | 久久国产福利 | 热99久久精品 | 婷婷精品视频 | 天天摸天天干天天操天天射 | 国产va在线| 九九久久影视 | 婷婷成人亚洲综合国产xv88 | 在线免费观看麻豆视频 | av成人在线播放 | 怡红院av| 天天操天天干天天操天天干 | 99久久精品国产一区二区三区 | 五月婷婷.com| 国产99在线播放 | av资源网在线播放 | 国产精品九九久久久久久久 | aaa毛片视频 | 久久久久国产精品免费免费搜索 | 久久人人爽爽人人爽人人片av | 香蕉成人在线视频 | 九九免费精品 | 亚洲精品裸体 | 欧美一二区在线 | 久久99久久99精品免视看婷婷 | 青草视频在线 | av网站播放| a在线一区| 成年人在线观看 | 夜夜骑日日操 | 亚洲视屏| 91av片| 天天舔天天搞 | 成年人黄色免费视频 | 国产精品高潮呻吟久久av无 | www.天天射| 久久久蜜桃 | 日韩偷拍精品 | 在线视频 日韩 | 国产 在线 日韩 | 伊人色综合网 | 国产精品1区2区3区在线观看 | 免费观看高清 | 81精品国产乱码久久久久久 | 久久dvd| 久久影院午夜论 | 热久久这里只有精品 | 日韩欧美一区二区在线播放 | 国产在线精 | 日韩网站在线免费观看 | 黄色国产大片 | 蜜臀av在线一区二区三区 | 免费成人看片 | 国产涩涩网站 | 中文字幕在线观看的网站 | 1024手机看片国产 | 在线导航av | 亚洲激情综合网 | 欧美不卡在线 | 一区二区三区日韩精品 | 中文字幕高清视频 | 日韩激情视频在线 | 天天色图 | 久久看片网站 | 激情综合狠狠 | 美女视频久久 | 97超碰成人在线 | 日日夜夜操av | 992tv在线成人免费观看 | 国产精品一区二区中文字幕 | 亚洲影视九九影院在线观看 | 久草资源在线观看 | 亚洲国产激情 | 97超级碰碰碰视频在线观看 | 亚洲免费观看视频 | 亚洲午夜av | 天天干天天干天天色 | 日韩午夜三级 | 97精品国产97久久久久久春色 | 久久五月激情 | 精品麻豆入口免费 | www.五月天激情 | 国产精品日韩久久久久 | 欧美精品一区二区在线观看 | 不卡中文字幕在线 | 国产精品乱码在线 | 久久精品99北条麻妃 | 五月花丁香婷婷 | 在线免费色 | 久草在线视频网站 | 亚洲天堂精品视频在线观看 | 欧美 亚洲 另类 激情 另类 | 亚洲最快最全在线视频 | 日韩高清免费在线 | 国内综合精品午夜久久资源 | 亚洲黄色免费在线看 | 日韩成人不卡 | 中文字幕在线观看的网站 | 亚洲丝袜一区二区 | 91精品久久久久久综合乱菊 | 国产日韩高清在线 | 综合精品久久久 | 偷拍福利视频一区二区三区 | 成人在线免费视频 | 久草男人天堂 | 日本一区二区三区视频在线播放 | 99久久精品久久久久久清纯 | 美女网站在线 | www.天天射 | 欧美成人理伦片 | 伊人资源站| 麻豆国产在线视频 | 亚洲国产天堂av | 亚洲欧美激情插 | 国内外成人在线视频 | 丁香狠狠 | 激情婷婷综合网 | 色欧美综合 | 国产亚洲婷婷免费 | 日韩精品一区二区三区不卡 | 国产盗摄精品一区二区 | avsex| 人人网人人爽 | 国产精品美 | 免费看三级黄色片 | www.97色.com| 在线之家免费在线观看电影 | 亚洲精品字幕在线 | 国产精品久久久久久久久久久久久久 | 91精品无人成人www | 久草在线视频网站 | 国产麻豆精品在线观看 | 超碰国产在线观看 | 久久综合狠狠综合久久激情 | 久久婷婷精品视频 | 伊人五月天综合 | 久久久久久久久久久影院 | 亚洲精品午夜国产va久久成人 | 免费在线观看成人小视频 | 日韩三级精品 | 久热电影| 欧美精品中文 | 色偷偷人人澡久久超碰69 | 国产日本亚洲高清 | 日韩欧美69 | 欧美一级片在线观看视频 | 亚洲乱亚洲乱亚洲 | 国产精品女同一区二区三区久久夜 | 一级成人网| 美女黄频视频大全 | 麻豆影视在线免费观看 | 天天色棕合合合合合合 | 九九九九精品九九九九 | 超碰在线网 | 国产一级做a爱片久久毛片a | www.色午夜.com | 色综合亚洲精品激情狠狠 | 国产精品欧美久久久久三级 | 天天射天天射 | 人人澡视频 | 中文字幕在线专区 | 国产麻豆视频在线观看 | 最近高清中文字幕在线国语5 | 99欧美精品 | 能在线看的av| 亚洲成人av在线播放 | 免费看精品久久片 | 日本天天操 | 成年人网站免费在线观看 | 五月婷婷色播 | 国产热re99久久6国产精品 | 韩国av一区二区三区 | 日韩日韩日韩日韩 | 欧美三级在线播放 | 一本一本久久a久久精品综合小说 | 日韩免费视频线观看 | 国产99久久99热这里精品5 | 亚洲国产剧情av | 99久久精品无免国产免费 | 色综合久久网 | 黄色在线视频网址 | 精品一区二区免费 | 国产精品国产亚洲精品看不卡 | 天天操天天操天天操天天操天天操天天操 | 在线中文视频 | 日韩午夜电影院 | 性色在线视频 | 四虎成人精品永久免费av九九 | 国产亚洲精品中文字幕 | 欧美日韩国产精品一区 | 91天堂素人约啪 | 婷婷www| 国产精品免费观看视频 | 高清视频一区二区三区 | 婷婷国产精品 | 香蕉视频在线免费看 | 在线观看中文字幕 | 欧美极品少妇xbxb性爽爽视频 | 久久精品久久精品久久 | 日韩欧美国产视频 | 欧美色噜噜噜 | 免费在线激情电影 | a天堂最新版中文在线地址 久久99久久精品国产 | 国产99久久精品一区二区永久免费 | 欧美日韩国产精品爽爽 | 久久成人麻豆午夜电影 | 日本韩国精品一区二区在线观看 | 国产精品久久艹 | 欧美性受极品xxxx喷水 | 成人av av在线| 最近日韩中文字幕中文 | 欧美aa在线 | 亚洲a在线观看 | 激情欧美国产 | 中文字幕 在线看 | av黄色av | 亚洲精品国产麻豆 | 亚洲三级在线免费观看 | 久久精品欧美视频 | 成年人网站免费观看 | 欧美一级久久久 | 日韩在线免费电影 | 国产精品免费观看视频 | 超碰电影在线观看 | 免费在线h| 国产成人av一区二区三区在线观看 | 中国一级片在线 | 久久久私人影院 | 成年人av在线播放 | 视频直播国产精品 | 五月天欧美精品 | 人人爽久久涩噜噜噜网站 | 丁香午夜 | 一区二区三区在线看 | 天天综合色网 | 天天操天天操天天操天天 | 一区二区视频在线看 | 91精品在线视频 | 色综合天天做天天爱 | 国产免费高清视频 | 日韩网站在线免费观看 | 亚洲春色奇米影视 | 久草免费在线 | 麻豆视频一区二区 | 99视频精品免费观看, | 久久这里有精品 | 亚洲精品视频在线免费播放 | 九色激情网 | 激情综合婷婷 | 日韩激情视频 | 日韩二级毛片 | 国产福利av在线 | 欧美日韩中文在线 | 日韩毛片在线免费观看 | 中文字幕最新精品 | 婷婷 中文字幕 | 美女视频久久黄 | 色婷婷五 | 国产69熟 | 久久国产网站 | 国产va在线观看免费 | 国产69久久久欧美一级 | 国产一区二区手机在线观看 | 六月丁香激情综合 | 日韩av进入| 在线小视频你懂得 | 天天操天天摸天天射 | 国产精品美女视频网站 | 国产精品久久二区 | 91漂亮少妇露脸在线播放 | 99精品视频免费 | 在线中文字幕网站 | 中文字幕乱码电影 | 黄色小说网站在线 | 国产资源在线免费观看 | 久久国际影院 | 国产日韩精品一区二区三区 | 91tv国产成人福利 | 国产资源av| 91精品国产91久久久久久三级 | 看片一区二区三区 | 波多野结衣视频在线 | 日韩免费视频一区二区 | 色婷婷色 | 亚洲五月激情 | 波多野结衣电影一区 | 久久综合久久伊人 | 少妇搡bbbb搡bbb搡aa | 久草在线中文888 | 99精品久久只有精品 | 午夜久久久久久久 | 在线观看黄网站 | free. 性欧美.com | 国产最新在线视频 | 成人毛片一区二区三区 | 在线观看韩国av | 香蕉网站在线观看 | 亚洲免费精品一区二区 | 亚洲无人区小视频 | 免费视频久久 | 99免费在线视频观看 | 香蕉免费在线 | 在线视频app| 国产又粗又猛又黄又爽的视频 | 国产精品免费在线视频 | 国产免费又爽又刺激在线观看 | 91欧美精品| 午夜电影 电影 | 日本三级人妇 | 六月丁香婷婷久久 | 制服丝袜天堂 | 天天爽网站 | 成人一级免费电影 | 特级西西www44高清大胆图片 | 一区二区三区四区在线 | 中文字幕av电影下载 | 6080yy午夜一二三区久久 | 97超视频 | 97福利在线观看 | 国产黄免费看 | av久久在线 | 久久综合国产伦精品免费 | 亚洲波多野结衣 | 久久一区91 | 国产一区二区三区四区大秀 | 成人精品国产 |