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

基于Docker搭建Redis主從集群的實(shí)現(xiàn)

 更新時(shí)間:2021年05月14日 12:07:47   作者:niceyoo  
本文基于Docker+Redis5.0.5版本,通過(guò)cluster方式創(chuàng)建一個(gè)6個(gè)redis實(shí)例的主從集群,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

最近陸陸續(xù)續(xù)有不少園友加我好友咨詢 redis 集群搭建的問(wèn)題,我覺(jué)得一定是之前寫的這篇 《基于Docker的Redis集群搭建》 文章有問(wèn)題了,所以我花了幾分鐘瀏覽之前的文章總結(jié)了下面幾個(gè)問(wèn)題:

redis 數(shù)量太少,只創(chuàng)建了 3 個(gè)實(shí)例;由于只有 3 個(gè)實(shí)例,所以全部只能是主節(jié)點(diǎn),無(wú)法體現(xiàn)集群主從關(guān)系;如何搭建主從集群?如何分配從節(jié)點(diǎn)?

基于之前的文章,我想快速的過(guò)一下這幾個(gè)問(wèn)題,本文基于 Docker + Redis 5.0.5 版本,通過(guò) cluster 方式創(chuàng)建一個(gè) 6 個(gè) redis 實(shí)例的主從集群,當(dāng)然文章會(huì)指出相應(yīng)的參數(shù)說(shuō)明,這樣即便是創(chuàng)建 9 個(gè)實(shí)例的集群方式也是一樣的。

1、拉取 Redis 鏡像

基于 Redis:5.0.5 版本,執(zhí)行如下指令:

docker pull redis:5.0.5

2、創(chuàng)建 6 個(gè) Redis 容器

創(chuàng)建 6 個(gè)Redis 容器:

  • redis-node1:6379
  • redis-node2:6380
  • redis-node3:6381
  • redis-node4:6382
  • redis-node5:6383
  • redis-node6:6384

執(zhí)行命令如下:

docker create --name redis-node1 --net host -v /data/redis-data/node1:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-1.conf --port 6379

docker create --name redis-node2 --net host -v /data/redis-data/node2:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-2.conf --port 6380

docker create --name redis-node3 --net host -v /data/redis-data/node3:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-3.conf --port 6381

docker create --name redis-node4 --net host -v /data/redis-data/node4:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-4.conf --port 6382

docker create --name redis-node5 --net host -v /data/redis-data/node5:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-5.conf --port 6383

docker create --name redis-node6 --net host -v /data/redis-data/node6:/data redis:5.0.5 --cluster-enabled yes --cluster-config-file nodes-node-6.conf --port 6384

部分參數(shù)解釋:

  • --cluster-enabled:是否啟動(dòng)集群,選值:yes 、no
  • --cluster-config-file 配置文件.conf :指定節(jié)點(diǎn)信息,自動(dòng)生成
  • --cluster-node-timeout 毫秒值: 配置節(jié)點(diǎn)連接超時(shí)時(shí)間
  • --appendonly:是否開(kāi)啟持久化,選值:yes、no

執(zhí)行命令截圖:

3、啟動(dòng) Redis 容器

執(zhí)行命令如下:

docker start redis-node1 redis-node2 redis-node3 redis-node4 redis-node5 redis-node6

啟動(dòng)截圖如下:

4、組建 Redis 集群

進(jìn)入任意一個(gè) Redis 實(shí)例:

# 這里以 redis-node1 實(shí)例為例
docker exec -it redis-node1 /bin/bash

執(zhí)行組件集群的命令:

# 組建集群,10.211.55.4為當(dāng)前物理機(jī)的ip地址
redis-cli --cluster create 10.211.55.4:6379 10.211.55.4:6380 10.211.55.4:6381 10.211.55.4:6382 10.211.55.4:6383 10.211.55.4:6384 --cluster-replicas 1

執(zhí)行命令截圖如下:

創(chuàng)建成功后,通過(guò) redis-cli 查看一下集群節(jié)點(diǎn)信息:

root@CentOS7:/data# redis-cli
127.0.0.1:6379> cluster nodes

執(zhí)行命令截圖如下:

5、關(guān)于Redis集群搭建

我們?cè)倩氐絼?chuàng)建集群的命令上:

redis-cli --cluster create 10.211.55.4:6379~6384 --cluster-replicas 1

大家著重看這個(gè)參數(shù) --cluster-replicas 1,參數(shù)后面的數(shù)字表示的是主從比例,比如這里的 1 表示的是主從比例是 1:1,什么概念呢?

也就是 1 個(gè)主節(jié)點(diǎn)對(duì)應(yīng)幾個(gè)從節(jié)點(diǎn),現(xiàn)有 6 個(gè)實(shí)例,所以主從分配就是 3 個(gè) master 主節(jié)點(diǎn),3 個(gè) slave 從節(jié)點(diǎn)。

主節(jié)點(diǎn)最少3個(gè),3個(gè)才能保證集群的健壯性。

如果 --cluster-replicas 2 呢?

那么主從比例就是 1:2,也就是 1 個(gè)主節(jié)點(diǎn)對(duì)于應(yīng) 2 個(gè)從節(jié)點(diǎn)。

即:3(master) + 6(slave) = 9個(gè) Redis 實(shí)例。

如果不足 9個(gè) Redis 實(shí)例,但是參數(shù)指定為 2 會(huì)怎么樣?

報(bào)錯(cuò)信息如下:

提示已經(jīng)很清楚了,Redis集群至少需要3個(gè)主節(jié)點(diǎn)。那么從節(jié)點(diǎn)就需要有6個(gè),所以最后說(shuō):至少需要9個(gè)節(jié)點(diǎn)。

好的,至少3個(gè)主節(jié)點(diǎn)的要求我不繼續(xù)剛了,但是我想4個(gè)主節(jié)點(diǎn),2個(gè)從節(jié)點(diǎn),這總該可以了吧?

4個(gè)主節(jié)點(diǎn)滿足你:

# 進(jìn)入一個(gè)啟動(dòng)的 reids 實(shí)例,這里以 redis-node1 實(shí)例為例
docker exec -it redis-node1 /bin/bash

執(zhí)行組建集群的命令:

redis-cli --cluster create 10.211.55.4:6379 10.211.55.4:6380 10.211.55.4:6381 10.211.55.4:6382  --cluster-replicas 0

指定4個(gè)沒(méi)有從節(jié)點(diǎn)的主節(jié)點(diǎn),這樣你就有4個(gè)主節(jié)點(diǎn)了:

剩下的兩個(gè)從節(jié)點(diǎn)怎么辦呢?手動(dòng)添加。

怎么添加?手動(dòng)添加!

看到這些 master 節(jié)點(diǎn)的 id 了嗎,只需要把 slave 指定給他們就可以了。

繼續(xù)執(zhí)行如下命令:

redis-cli --cluster add-node 10.211.55.4:6383 10.211.55.4:6379  --cluster-slave --cluster-master-id b0c32b1dae9e7b7f7f4b74354c59bdfcaa46f30a

redis-cli --cluster add-node 10.211.55.4:6384 10.211.55.4:6379  --cluster-slave --cluster-master-id 111de8bed5772585cef5280c4b5225ecb15a582e

將兩個(gè) Redis 實(shí)例塞給其他主節(jié)點(diǎn)了:

最后我們進(jìn)入 redis-cli,通過(guò) cluster nodes 查看一下節(jié)點(diǎn)信息:

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

相關(guān)文章

  • 使用 Docker 部署 Apache Spark 集群的過(guò)程

    使用 Docker 部署 Apache Spark 集群的過(guò)程

    本文介紹了如何使用Docker和DockerCompose快速部署一個(gè)包含一個(gè)Master節(jié)點(diǎn)和兩個(gè)Worker節(jié)點(diǎn)的Spark集群,通過(guò)創(chuàng)建docker-compose.yml文件并執(zhí)行相關(guān)命令,可以實(shí)現(xiàn)集群的構(gòu)建和啟動(dòng),感興趣的朋友一起看看吧
    2025-02-02
  • 使用Docker部署前后端分離項(xiàng)目的完整步驟

    使用Docker部署前后端分離項(xiàng)目的完整步驟

    剛剛接觸基礎(chǔ)的運(yùn)維工作,采用的是docker部署的方式,下面這篇文章主要給大家介紹了關(guān)于使用Docker部署前后端分離項(xiàng)目的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-01-01
  • Docker 鏡像和容器的區(qū)別詳解

    Docker 鏡像和容器的區(qū)別詳解

    這篇文章主要介紹了Docker 鏡像和容器的區(qū)別詳解的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • docker build上下文的實(shí)現(xiàn)示例

    docker build上下文的實(shí)現(xiàn)示例

    Docker build上下文是構(gòu)建Docker鏡像時(shí)傳遞給Docker引擎的所有文件和目錄的集合,可以提高構(gòu)建效率,避免無(wú)用文件的傳輸,同時(shí)確保鏡像構(gòu)建過(guò)程的順利進(jìn)行,感興趣的可以了解一下
    2025-09-09
  • Docker配置Redis集群及主從擴(kuò)容與縮容的操作方法

    Docker配置Redis集群及主從擴(kuò)容與縮容的操作方法

    這篇文章主要介紹了Docker配置Redis集群及主從擴(kuò)容與縮容的操作方法,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • CentOS7上安裝Docker的詳細(xì)步驟

    CentOS7上安裝Docker的詳細(xì)步驟

    Docker?是一個(gè)開(kāi)源工具,它可以讓創(chuàng)建和管理?Linux?容器變得簡(jiǎn)單,容器就像是輕量級(jí)的虛擬機(jī),并且可以以毫秒級(jí)的速度來(lái)啟動(dòng)或停止,下面這篇文章主要給大家介紹了關(guān)于CentOS7上安裝Docker的詳細(xì)步驟,需要的朋友可以參考下
    2022-01-01
  • kubernetes作用領(lǐng)域總結(jié)

    kubernetes作用領(lǐng)域總結(jié)

    在本文里我們給大家整理關(guān)于kubernetes作用領(lǐng)域以及可以做的項(xiàng)目和思路,有興趣的朋友們參考下。
    2019-06-06
  • Docker部署MinIO鏡像的方法(保姆級(jí)教程)

    Docker部署MinIO鏡像的方法(保姆級(jí)教程)

    本文主要介紹了使用Docker部署MinIO鏡像,包括創(chuàng)建掛載目錄、運(yùn)行MinIO容器的參數(shù)解析、使用Compose運(yùn)行MinIO容器等,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-12-12
  • .Net8項(xiàng)目使用docker、docker-compose部署的圖文步驟

    .Net8項(xiàng)目使用docker、docker-compose部署的圖文步驟

    本文主要介紹了.Net8項(xiàng)目使用docker、docker-compose部署的圖文步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2025-04-04
  • Win10系統(tǒng)使用docker部署ragflow的實(shí)現(xiàn)

    Win10系統(tǒng)使用docker部署ragflow的實(shí)現(xiàn)

    本文主要介紹了Win10系統(tǒng)使用docker部署ragflow的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2025-05-05

最新評(píng)論