Docker搭建redis集群的實(shí)現(xiàn)
1.使用docker新建6個(gè)redis容器實(shí)例
在此之前,需要在阿里云服務(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.進(jìn)入容器redis-node-1,為六臺(tái)容器構(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é)點(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)
3.1 docker exec -it redis-node-1 /bin/bash
3.2redis-cli -p 6381
3.3cluster info
3.4 cluster nodes (這條命令是查看哪個(gè)節(jié)點(diǎn)是主節(jié)點(diǎn),哪個(gè)節(jié)點(diǎn)是從節(jié)點(diǎn),以及槽點(diǎn)范圍)
4.測試主從容錯(cuò)切換遷移
4.1 進(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 先對 key 使用 crc16 算法算出一個(gè)結(jié)果,然后把結(jié)果對 16384 求余數(shù),這樣每個(gè) key 都會(huì)對應(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è)容器中
4.2 ctrl+c,退出redis-cli
4.3 查看集群信息 redis-cli --cluster check 8.136.84.238:6381
4.4 測試將6386(master)容器停止,6381從機(jī)會(huì)代替主機(jī)6386的位置上位,變成master主機(jī)
5.主從擴(kuò)容
5.1 以集群方式新建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
5.2 進(jìn)入6387容器內(nèi)部
docker exec -it redis-node-7 /bin/bash
5.3 將新增的6387節(jié)點(diǎn)作為master節(jié)點(diǎn)加入原集群(我這里是通過6381建立redis集群的,
6381容器就是原來集群節(jié)點(diǎn)里面的領(lǐng)路人,相當(dā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 重新分配槽號(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
5.6查看槽點(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
5.7 為主節(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
5.8 檢查集群情況 發(fā)現(xiàn)已經(jīng)分好
6.主從縮容
6.1 將6387 6388兩個(gè)節(jié)點(diǎn)下線
6.2 檢查集群情況,獲得6388的節(jié)點(diǎn)id
redis-cli --cluster check 8.136.84.238:6388
6.4 從集群中將6388節(jié)點(diǎn)刪除
redis-cli --cluster del-node 8.136.84.238:6388 da2567b5be3ac4b92b02abed931ff15ea04011e0
6.5 將6387的槽號(hào)清空,重新分配槽號(hào),并都給主機(jī)(一定要是主機(jī),而不是從機(jī))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é)點(diǎn)已經(jīng)沒有為它分配槽點(diǎn)了,轉(zhuǎn)而全部分給了其他容器節(jié)點(diǎn)
6.7 將6387剔除掉該集群
redis-cli --cluster del-node 8.136.84.238:6387 f8cabc7a47b374a8838bd75ab34c6e9804781d3f
6.8 重新查看集群,發(fā)現(xiàn)兩個(gè)節(jié)點(diǎn)都已剔除,并實(shí)現(xiàn)了縮容
到此這篇關(guān)于Docker搭建redis集群的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Docker搭建redis集群內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用docker極簡打包java.jar鏡像并啟動(dòng)的操作步驟
這篇文章主要介紹了用docker極簡打包java.jar鏡像并啟動(dòng),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08如何進(jìn)入、退出docker的container實(shí)現(xiàn)
這篇文章主要介紹了如何進(jìn)入、退出docker的container實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11Docker使用Calico網(wǎng)絡(luò)模式配置及問題處理方法
這篇文章主要介紹了Docker使用Calico網(wǎng)絡(luò)模式配置及問題處理,設(shè)計(jì)思想是Calico不使用隧道或者NAT來實(shí)現(xiàn)轉(zhuǎn)發(fā),而是巧妙的把所有二三層流量轉(zhuǎn)換成三層流量,并通過host上路由配置完成跨host轉(zhuǎn)發(fā),需要的朋友可以參考下2022-11-11Docker部署Rabbitmq容器實(shí)現(xiàn)過程解析
這篇文章主要介紹了Docker部署Rabbitmq容器實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11快速使用docker-compose部署clickhouse的教程
ClickHouse 的工作速度比傳統(tǒng)方法快 100-1000 倍。它適用于大數(shù)據(jù)、業(yè)務(wù)分析和時(shí)間序列數(shù)據(jù)。在這個(gè)小教程中,我將向您展示如何以最少的設(shè)置安裝 ClickHouse,感興趣的朋友一起看看吧2021-11-11