欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Docker搭建redis集群教程

 更新時(shí)間:2025年08月13日 14:31:16   作者:蘇七qaq  
使用Docker部署6個(gè)Redis容器,配置集群并開(kāi)放6381/16381端口,測(cè)試主從切換與數(shù)據(jù)遷移,通過(guò)增刪節(jié)點(diǎn)實(shí)現(xiàn)擴(kuò)容縮容,調(diào)整槽位分配確保負(fù)載均衡

1.使用docker新建6個(gè)redis容器實(shí)例

在此之前,需要在阿里云服務(wù)器和寶塔界面開(kāi)放安全組(redis客戶端連接端口和集群總線端口)

redis集群不僅需要開(kāi)通redis客戶端連接的端口(如6381),而且需要開(kāi)通集群總線端口(16381)。

集群總線端口=redis客戶端連接的端口+10000

docker run -d --name redis-node-1 --net host --privileged=true -v /docker/redis/share/redis-node-1:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6381
docker run -d --name redis-node-2 --net host --privileged=true -v /docker/redis/share/redis-node-2:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6382
docker run -d --name redis-node-3 --net host --privileged=true -v /docker/redis/share/redis-node-3:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6383
docker run -d --name redis-node-4 --net host --privileged=true -v /docker/redis/share/redis-node-4:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6384
docker run -d --name redis-node-5 --net host --privileged=true -v /docker/redis/share/redis-node-5:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6385
docker run -d --name redis-node-6 --net host --privileged=true -v /docker/redis/share/redis-node-6:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6386 

命令解釋:

2.進(jìn)入容器redis-node-1,為六臺(tái)容器構(gòu)建集群關(guān)系

docker exec -it redis-node-1 /bin/bash
redis-cli --cluster create 8.136.84.238:6381 8.136.84.238:6382 8.136.84.238:6383 8.136.84.238:6384 8.136.84.238:6385 8.136.84.238:6386 --cluster-replicas 1

--cluster-replicas 1 表示集群主節(jié)點(diǎn)需要多少個(gè)從節(jié)點(diǎn),我們用了6臺(tái),即3臺(tái)服務(wù)器構(gòu)成集群,每臺(tái)服務(wù)器設(shè)置1臺(tái)從服務(wù)器

3.進(jìn)入端口為6381的redis容器,并查看集群狀態(tài)

docker exec -it redis-node-1 /bin/bash
redis-cli -p 6381
cluster info

cluster nodes (這條命令是查看哪個(gè)節(jié)點(diǎn)是主節(jié)點(diǎn),哪個(gè)節(jié)點(diǎn)是從節(jié)點(diǎn),以及槽點(diǎn)范圍)

4.測(cè)試主從容錯(cuò)切換遷移

進(jìn)入端口為6381的容器,新增兩個(gè)key,這里需要加-c,集群操作,可以將key-value放入其他容器中

Redis 集群中內(nèi)置了 16384 個(gè)哈希槽,redis 會(huì)根據(jù)節(jié)點(diǎn)數(shù)量大致均等的將哈希槽映射到不同的節(jié)點(diǎn)。

當(dāng)需要在 Redis 集群中放置一個(gè) key-value時(shí),redis 先對(duì) key 使用 crc16 算法算出一個(gè)結(jié)果,然后把結(jié)果對(duì) 16384 求余數(shù),這樣每個(gè) key 都會(huì)對(duì)應(yīng)一個(gè)編號(hào)在 0-16383 之間的哈希槽,也就是映射到某個(gè)節(jié)點(diǎn)上。

如下代碼,key之A 、B在Node2, key之C落在Node3上

因此,可以看到第一個(gè)k1 v1會(huì)落到范圍包括12706這個(gè)槽點(diǎn)中,也就是6383這個(gè)容器中,

k2 v2會(huì)落到包括449這個(gè)范圍的槽點(diǎn)中,也就是6386這個(gè)容器中

  • ctrl+c,退出redis-cli
  • 查看集群信息 redis-cli --cluster check 8.136.84.238:6381

  • 測(cè)試將6386(master)容器停止,6381從機(jī)會(huì)代替主機(jī)6386的位置上位,變成master主機(jī)

5.主從擴(kuò)容

以集群方式新建6387、6388兩個(gè)節(jié)點(diǎn)

docker run -d --name redis-node-7 --net host --privileged=true -v /docker/redis/share/redis-node-7:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6387
docker run -d --name redis-node-8 --net host --privileged=true -v /docker/redis/share/redis-node-8:/data redis:6.2.6 --cluster-enabled yes --appendonly yes --port 6388

進(jìn)入6387容器內(nèi)部

docker exec -it redis-node-7 /bin/bash

將新增的6387節(jié)點(diǎn)作為master節(jié)點(diǎn)加入原集群(我這里是通過(guò)6381建立redis集群的,

6381容器就是原來(lái)集群節(jié)點(diǎn)里面的領(lǐng)路人,相當(dāng)于6387拜拜6381的碼頭從而找到組織加入集群)

redis-cli --cluster add-node 8.136.84.238:6387 8.136.84.238:6381

檢查是否加入該redis集群

redis-cli --cluster check 8.136.84.238:6381

重新分配槽號(hào)

redis-cli --cluster reshard 8.136.84.238:6381

這里分配的槽號(hào)數(shù)=16384/機(jī)器數(shù) =》 分配的槽號(hào)數(shù)=16384/4=4096

這里該節(jié)點(diǎn)的id號(hào),應(yīng)該為新節(jié)點(diǎn)6387的節(jié)點(diǎn)號(hào)

這里是所有節(jié)點(diǎn)都分配4096個(gè)槽點(diǎn),所以為all

查看槽點(diǎn)的分配

redis-cli --cluster check 8.136.84.238:6381

 為什么6387容器分配的槽點(diǎn)是3個(gè)新的區(qū)間,因?yàn)橹匦路峙涑杀咎?,所以前面三家勻出一部分?/p>

從6381/6382/6383三個(gè)舊節(jié)點(diǎn)分別勻出1364個(gè)坑位給新節(jié)點(diǎn)6387

為主節(jié)點(diǎn)6387分配從節(jié)點(diǎn)6388

redis-cli --cluster add-node 8.136.84.238:6388 8.136.84.238:6387 --cluster-slave --cluster-master-id f8cabc7a47b374a8838bd75ab34c6e9804781d3f

檢查集群情況 發(fā)現(xiàn)已經(jīng)分好

6.主從縮容

將6387 6388兩個(gè)節(jié)點(diǎn)下線

檢查集群情況,獲得6388的節(jié)點(diǎn)id

redis-cli --cluster check 8.136.84.238:6388

從集群中將6388節(jié)點(diǎn)刪除

redis-cli --cluster del-node 8.136.84.238:6388 da2567b5be3ac4b92b02abed931ff15ea04011e0

將6387的槽號(hào)清空,重新分配槽號(hào),并都給主機(jī)(一定要是主機(jī),而不是從機(jī))6381

redis-cli --cluster reshard 8.136.84.238:6381

檢查集群情況

redis-cli --cluster check 8.136.84.238:6381

發(fā)現(xiàn)6387節(jié)點(diǎn)已經(jīng)沒(méi)有為它分配槽點(diǎn)了,轉(zhuǎn)而全部分給了其他容器節(jié)點(diǎn)

將6387剔除掉該集群

redis-cli --cluster del-node 8.136.84.238:6387 f8cabc7a47b374a8838bd75ab34c6e9804781d3f

重新查看集群,發(fā)現(xiàn)兩個(gè)節(jié)點(diǎn)都已剔除,并實(shí)現(xiàn)了縮容

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 使用Dockerfile.dockerignore提升Docker鏡像構(gòu)建速度

    使用Dockerfile.dockerignore提升Docker鏡像構(gòu)建速度

    這篇文章主要為大家介紹了使用Dockerfile.dockerignore提升Docker鏡像構(gòu)建速度,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪<BR>
    2023-10-10
  • 詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

    詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐

    這篇文章主要介紹了詳解使用Docker進(jìn)行Redis主從復(fù)制實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • docker安裝redis并以配置文件方式啟動(dòng)詳解

    docker安裝redis并以配置文件方式啟動(dòng)詳解

    這篇文章主要介紹了docker安裝redis并以配置文件方式啟動(dòng)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • docker啟動(dòng)nginx及常見(jiàn)nginx配置方式

    docker啟動(dòng)nginx及常見(jiàn)nginx配置方式

    這篇文章主要介紹了docker啟動(dòng)nginx及常見(jiàn)nginx配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • docker端口映射及外部無(wú)法訪問(wèn)問(wèn)題

    docker端口映射及外部無(wú)法訪問(wèn)問(wèn)題

    這篇文章主要介紹了docker端口映射及外部無(wú)法訪問(wèn)問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • docker?run命令的使用小結(jié)

    docker?run命令的使用小結(jié)

    本文主要介紹了docker?run命令的使用小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2025-01-01
  • docker-compose部署zk+kafka+storm集群的實(shí)現(xiàn)

    docker-compose部署zk+kafka+storm集群的實(shí)現(xiàn)

    這篇文章主要介紹了docker-compose部署zk+kafka+storm集群,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • docker的pdflatex環(huán)境配置的方法步驟

    docker的pdflatex環(huán)境配置的方法步驟

    這篇文章主要介紹了docker的pdflatex環(huán)境配置的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Docker系列compose?ymal文件解析學(xué)習(xí)

    Docker系列compose?ymal文件解析學(xué)習(xí)

    這篇文章主要介紹了Docker系列之compose?ymal文件解析學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • CentOS7安裝使用Docker的步驟

    CentOS7安裝使用Docker的步驟

    本篇文章主要介紹了詳解CentOS7安裝使用Docker的步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-06-06

最新評(píng)論