亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

【NoSQL】拋棄VIP,使用consul和sentinel構建redis的高可用系統

發布時間:2020-07-20 14:52:22 來源:網絡 閱讀:4133 作者:對唔住 欄目:關系型數據庫

背景:

1.傳統redis高可用方案只加了sentinel,在主庫故障后,雖然可以選主,然后切換只讀參數,但是,對應用來說卻需要更改連接的IP或者在hosts中更改解析。算得上是半自動。
2.利用consul系統的服務注冊與服務健康檢查功能可以實現全自動的故障切換與地址解析。

架構:

【NoSQL】拋棄VIP,使用consul和sentinel構建redis的高可用系統

搭建:

1.建立consul集群,在redis節點上布置consul agent
2.建立sentinel集群
3.注冊服務(重點)

  • 首先在redis2222實例上新建redis主從檢測腳本
    cat >/root/check/redis_role.sh<<EOF
    #!/bin/bash
    PORT=$1
    ROLE=$2
    a=$(redis-cli -p $PORT info Replication|grep role:|awk -F ':' '{print $2}'|awk -F '\r' '{print $1}' )
     if [ $a = $ROLE ]; then
     exit 0
    else
     exit 2
        fi
    EOF

    注:腳本使用方式:/root/check/redis_role.sh 2222 master
    第一個參數2222代表端口
    第二個參數master代表主,也可使用slave
    原理:摘出info命令中replication段的role屬性,然后和第二個變量相對比,相同,則輸出0
    (shell腳本正常運行的返回值),否則返回2(shell腳本執行異常的返回值)

  • 其次:創建consul的redis服務配置文件
        cat >/etc/consu/redis_2222.json<<EOF
         {
            "services":[
                {
                 "id":"2222master",
                 "name":"redis-master",
                 "tags":["master"],
                 "address":"192.168.1.131",
                 "port":2222,
                 "check":[
                                {
                                    "args":["/root/check/redis_role.sh","2222","master"],
                                    "interval":"3s"
                                 }
                               ]
                },
                {
                 "id":"2222slave",
                 "name":"2222slave"
                 "tags":["slave"]
                 "address":"192.168.1.131"
                 "port":2222
                 "checks":[
                                 {
                                    "args":["/root/check/redis_role.sh","2222","slave"],
                                    "interval":"3s"
                                  }
                                ]
                }
            ]
        }
        EOF

    在redis3333實例所在的主機上同樣操作。
    解釋:在2222實例上我們注冊兩個服務,一個為redis-master,一個為redis-slave。
    在3333實例上也注冊了同樣的兩個服務,在consul系統中,將json配置文件中name屬性相同的
    服務視為同一個服務。因為consul本身是具備健康檢查的功能,一個服務中如果兩個節點都OK
    服務域名解析是將會輪詢到兩個節點中,但健康檢查失敗后,域名解析時會自動踢出fail節點。


    情況1:redis2222為主實例,redis3333為從實例
          通過在腳本對redis的主從屬性進行檢查, "args":["/root/check/redis_role.sh","2222","master"],
    在腳本中,我們設置了讀取傳入的兩個參數并進行使用,在consul配置文件中,對傳入參數
    需要使用“,”分割,并且無論數字或者字符串都需要加上雙引號。
    2222的實例中role為master,3333的實例role為 slave。分別滿足了redis-master和redis-slave
    的健康檢查,consul在解析redis-master.service.consul和redis-slave.service.consul時分別指向
    了redis2222的主機和redis3333的地址。
    此時:   ping redis-master.service.consul 》192.168.1.131
                  ping redis-slave.service.consul 》192.168.1.104
                  APP可以通過redis-master.service.consul:2222對redis進行寫入,
                  通過redis-master.service.consul:3333對redis進行分散讀請求
    consul web頁面如圖

【NoSQL】拋棄VIP,使用consul和sentinel構建redis的高可用系統
【NoSQL】拋棄VIP,使用consul和sentinel構建redis的高可用系統


情況2:redis2222節點故障,sentinel自動提升redis3333節點為主節點,2222重新上線后,被
    sentinel集群配置為指向3333的從節點。
         此時: ping redis-master.service.consul 》192.168.1.104
               ping redis-slave.service.consul 》192.168.1.131
    APP可以通過redis-master.service.consul:3333對redis進行寫入,
    通過redis-master.service.consul:2222對redis進行分散讀請求
    consul web頁面如圖

【NoSQL】拋棄VIP,使用consul和sentinel構建redis的高可用系統
【NoSQL】拋棄VIP,使用consul和sentinel構建redis的高可用系統


后記:   
    1.本文中為了顯著區分兩個redis實例,對端口進行了區分,實際應用推薦使用相同端口(如2222)
        這樣每次訪問redis-master.service.consul:2222都能訪問到主實例
            每次訪問redis-master.service.consul:2222都能訪問到從實例
    2. consul定期執行健康檢測腳本并接收返回值0作為服務處于正常的標志,返回值1作為服務處于警告
      狀態,除此之外任何其他返回值都被認為服務處于故障狀態。實際使用時根據自身情況設置健康檢測腳本
      執行的頻率
    3.這種切換架構的便利性建立在數據庫端可以自洽的完成主從選舉與切換的特性上,同理,這種思路還
      可以用在consul+MongoDB副本集,consul+PXC集群上。
    4.官方文檔地址:`https://www.consul.io/docs/index.html`
      相關配置文件已放置在GitHub:`https://github.com/naughtyGitCat/HA_DB/tree/master/Consul`
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

和平区| 平塘县| 定日县| 汕头市| 徐闻县| 太和县| 涞水县| 怀来县| 古丈县| 滁州市| 镇巴县| 景洪市| 乌审旗| 厦门市| 岗巴县| 林甸县| 禹城市| 梓潼县| 巴青县| 杭锦旗| 垦利县| 凯里市| 察隅县| 香港| 桦甸市| 大悟县| 资源县| 锦屏县| 彭山县| 色达县| 乡城县| 开封市| 门头沟区| 应用必备| 白沙| 河间市| 霍林郭勒市| 禹州市| 连城县| 临江市| 怀集县|