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

Docker搭建redis集群的實現(xiàn)

 更新時間:2025年02月11日 09:31:39   作者:m0_74825678  
本文主要介紹了Docker搭建redis集群的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

1.使用docker新建6個redis容器實例

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

redis集群不僅需要開通redis客戶端連接的端口(如6381),而且需要開通集群總線端口(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.進入容器redis-node-1,為六臺容器構(gòu)建集群關(guān)系

2.1 docker exec -it redis-node-1 /bin/bash

2.2 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é)點需要多少個從節(jié)點,我們用了6臺,即3臺服務(wù)器構(gòu)成集群,每臺服務(wù)器設(shè)置1臺從服務(wù)器

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

3.1 docker exec -it redis-node-1 /bin/bash

3.2redis-cli -p 6381

3.3cluster info

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

4.測試主從容錯切換遷移

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

Redis 集群中內(nèi)置了 16384 個哈希槽,redis 會根據(jù)節(jié)點數(shù)量大致均等的將哈希槽映射到不同的節(jié)點。當需要在 Redis 集群中放置一個 key-value時,redis 先對 key 使用 crc16 算法算出一個結(jié)果,然后把結(jié)果對 16384 求余數(shù),這樣每個 key 都會對應(yīng)一個編號在 0-16383 之間的哈希槽,也就是映射到某個節(jié)點上。如下代碼,key之A 、B在Node2, key之C落在Node3上

因此,可以看到第一個k1 v1會落到范圍包括12706這個槽點中,也就是6383這個容器中,

k2 v2會落到包括449這個范圍的槽點中,也就是6386這個容器中

4.2 ctrl+c,退出redis-cli

4.3 查看集群信息 redis-cli --cluster check 8.136.84.238:6381

4.4 測試將6386(master)容器停止,6381從機會代替主機6386的位置上位,變成master主機

5.主從擴容

5.1 以集群方式新建6387、6388兩個節(jié)點

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

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

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

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

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

redis-cli --clusteradd-node8.136.84.238:63878.136.84.238:6381

5.4 檢查是否加入該redis集群

redis-cli --cluster check 8.136.84.238:6381

5.5 重新分配槽號

redis-cli --cluster reshard 8.136.84.238:6381

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

這里該節(jié)點的id號,應(yīng)該為新節(jié)點6387的節(jié)點號

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

5.6查看槽點的分配

redis-cli --cluster check 8.136.84.238:6381

為什么6387容器分配的槽點是3個新的區(qū)間,因為重新分配成本太高,所以前面三家勻出一部分,

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

5.7 為主節(jié)點6387分配從節(jié)點6388

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

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

6.主從縮容

6.1 將6387 6388兩個節(jié)點下線

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

redis-cli --cluster check 8.136.84.238:6388

6.4 從集群中將6388節(jié)點刪除

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

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

redis-cli --cluster reshard 8.136.84.238:6381

6.6 檢查集群情況

redis-cli --cluster check 8.136.84.238:6381

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

6.7 將6387剔除掉該集群

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

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

到此這篇關(guān)于Docker搭建redis集群的實現(xiàn)的文章就介紹到這了,更多相關(guān)Docker搭建redis集群內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Docker修改容器內(nèi)部文件的三種方法

    Docker修改容器內(nèi)部文件的三種方法

    今天在修改Docker內(nèi)部文件的時候,安裝vim居然失敗了,在執(zhí)行apt-get update時一直有幾個404,解決無果,最后放棄安裝vim,將文件拷貝出來修改,所以本文給大家分享一下如何修改Docker內(nèi)部文件的方法,需要的朋友可以參考下
    2024-01-01
  • 使用docker極簡打包java.jar鏡像并啟動的操作步驟

    使用docker極簡打包java.jar鏡像并啟動的操作步驟

    這篇文章主要介紹了用docker極簡打包java.jar鏡像并啟動,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • 查看Docker容器的信息的方法實現(xiàn)

    查看Docker容器的信息的方法實現(xiàn)

    對于運行在Docker環(huán)境的容器,有時我們想查詢它們的一些基本信息,本文主要介紹了查看Docker容器的信息的方法實現(xiàn),文中根據(jù)實例編碼詳細介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Docker使用run命令部署Nginx的完整指南

    Docker使用run命令部署Nginx的完整指南

    容器化技術(shù)正在徹底改變現(xiàn)代應(yīng)用的部署方式,而 Docker 作為這一領(lǐng)域的先驅(qū),為開發(fā)者提供了快速構(gòu)建、交付和運行應(yīng)用的能力,下面小編就為大家介紹一下Docker如何通過run命令部署Nginx吧
    2025-03-03
  • 如何進入、退出docker的container實現(xiàn)

    如何進入、退出docker的container實現(xiàn)

    這篇文章主要介紹了如何進入、退出docker的container實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Docker使用Calico網(wǎng)絡(luò)模式配置及問題處理方法

    Docker使用Calico網(wǎng)絡(luò)模式配置及問題處理方法

    這篇文章主要介紹了Docker使用Calico網(wǎng)絡(luò)模式配置及問題處理,設(shè)計思想是Calico不使用隧道或者NAT來實現(xiàn)轉(zhuǎn)發(fā),而是巧妙的把所有二三層流量轉(zhuǎn)換成三層流量,并通過host上路由配置完成跨host轉(zhuǎn)發(fā),需要的朋友可以參考下
    2022-11-11
  • Docker存儲空間清理以及另外的一些命令

    Docker存儲空間清理以及另外的一些命令

    大家在使用一段時間的docker容器后,會發(fā)現(xiàn)堆疊了很多無用的垃圾文件,比如,終止的容器、限定不要的鏡像,混亂的存儲等,這篇文章主要介紹了Docker存儲空間清理以及另外的一些命令的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • Docker部署Rabbitmq容器實現(xiàn)過程解析

    Docker部署Rabbitmq容器實現(xiàn)過程解析

    這篇文章主要介紹了Docker部署Rabbitmq容器實現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-11-11
  • docker registry私服搭建的方法

    docker registry私服搭建的方法

    這篇文章主要介紹了docker registry私服搭建的方法,docker官方的registry鏡像分為兩個版本,v2和v2以前的版本,本文將分別搭建基于SSL和登錄認證的以上兩個版本的docker私服
    2018-05-05
  • 快速使用docker-compose部署clickhouse的教程

    快速使用docker-compose部署clickhouse的教程

    ClickHouse 的工作速度比傳統(tǒng)方法快 100-1000 倍。它適用于大數(shù)據(jù)、業(yè)務(wù)分析和時間序列數(shù)據(jù)。在這個小教程中,我將向您展示如何以最少的設(shè)置安裝 ClickHouse,感興趣的朋友一起看看吧
    2021-11-11

最新評論