溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

什么事是Redis集群

發(fā)布時(shí)間:2021-09-29 15:47:26 來(lái)源:億速云 閱讀:112 作者:iii 欄目:大數(shù)據(jù)

這篇文章主要介紹“什么事是Redis集群”,在日常操作中,相信很多人在什么事是Redis集群?jiǎn)栴}上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”什么事是Redis集群”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

集群搭建

2018年10月 Redis 發(fā)布了穩(wěn)定版本的 5.0 版本,推出了各種新特性,其中一點(diǎn)是集群管理工具從基于Ruby的redis-trib.rb移植到基于C語(yǔ)言redis-cli中,方便集群的構(gòu)建和管理

Redis Cluster集群運(yùn)行至少需要包含3個(gè)主節(jié)點(diǎn),實(shí)現(xiàn)高可用最少需要3主3從6個(gè)節(jié)點(diǎn)

以下步驟基于Redis 5.0.5版本,介紹如何在一臺(tái) Linux 服務(wù)器上搭建有3主3從的6節(jié)點(diǎn)的 Redis集群

  • 步驟1 創(chuàng)建安裝目錄

mkdir -p /data/project/redis-cluster
  • 步驟2 下載源碼并解壓編譯

cd /data/project/redis-cluster
wget http://download.redis.io/releases/redis-5.0.5.tar.gz
tar xzf redis-5.0.5.tar.gz
cd redis-5.0.5
make

執(zhí)行make后,如果報(bào)錯(cuò)“jemalloc/jemalloc.h:沒(méi)有那個(gè)文件或目錄”,可以改為用以下命令:

make MALLOC=libc
  • 步驟3 創(chuàng)建6個(gè)Redis配置文件 6個(gè)配置文件不能在同一個(gè)目錄,下面Redis 6個(gè)節(jié)點(diǎn)分別安裝在7000~7005端口 首先創(chuàng)建配置文件目錄及文件,定義如下:

mkdir -p /data/project/redis-cluster/nodes/7000
mkdir -p /data/project/redis-cluster/nodes/7001
mkdir -p /data/project/redis-cluster/nodes/7002
mkdir -p /data/project/redis-cluster/nodes/7003
mkdir -p /data/project/redis-cluster/nodes/7004
mkdir -p /data/project/redis-cluster/nodes/7005

touch /data/project/redis-cluster/nodes/7000/redis.conf
touch /data/project/redis-cluster/nodes/7001/redis.conf
touch /data/project/redis-cluster/nodes/7002/redis.conf
touch /data/project/redis-cluster/nodes/7003/redis.conf
touch /data/project/redis-cluster/nodes/7004/redis.conf
touch /data/project/redis-cluster/nodes/7005/redis.conf

redis.conf配置文件的內(nèi)容為:

############################## 網(wǎng)絡(luò) ##############################
# 端口
port 7000
# 非保護(hù)模式,如果值為yes,則必須是 bind配置指定的ip的機(jī)器連接或者使用密碼連接
protected-mode no 

############################## 通用 ##############################
# 后臺(tái)運(yùn)行
daemonize yes 
# 記錄redis進(jìn)程pid
pidfile  /var/run/redis_7000.pid

############################## 集群 ##############################
# 啟用集群模式
cluster-enabled yes 
cluster-config-file nodes_7000.conf
# 集群節(jié)點(diǎn)如果在該超時(shí)時(shí)間(毫秒)內(nèi)不可達(dá),則認(rèn)為節(jié)點(diǎn)處于故障狀態(tài)
cluster-node-timeout 5000

############################## 持久化 ##############################
# AOF, RDB持久化文件目錄
dir /data/project/redis-cluster/nodes
# 開(kāi)啟AOF持久化
appendonly yes
# AOF文件名
appendfilename "appendonly_7000.aof"
# 當(dāng)目前aof文件大小超過(guò)上一次重寫(xiě)的aof文件大小的百分之多少進(jìn)行重寫(xiě)
auto-aof-rewrite-percentage 100
# 設(shè)置允許重寫(xiě)的最小aof文件大小,避免了達(dá)到約定百分比但尺寸仍然很小的情況還要重寫(xiě)
auto-aof-rewrite-min-size 64mb
# RDB文件名
dbfilename dump_7000.rdb

其中 port 、 pidfile、cluster-config-file、appendfilename、 dbfilename配置需要隨著節(jié)點(diǎn)的不同而調(diào)整

配置項(xiàng)說(shuō)明可以參考redis-5.0.5/redis.conf,每一項(xiàng)都介紹得很詳細(xì),推薦閱讀

  • 步驟4 啟動(dòng)節(jié)點(diǎn)

/data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7000/redis.conf
/data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7001/redis.conf
/data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7002/redis.conf
/data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7003/redis.conf
/data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7004/redis.conf
/data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7005/redis.conf

ps -ef|grep redis,可以看到6個(gè)redis進(jìn)程已啟動(dòng):

什么事是Redis集群

  • 步驟5 啟動(dòng)集群 使用如下命令啟動(dòng)集群,IP地址自行替換:

/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster create 192.168.56.102:7000 192.168.56.102:7001 192.168.56.102:7002 192.168.56.102:7003 192.168.56.102:7004 192.168.56.102:7005 --cluster-replicas 1

啟動(dòng)成功信息如下:

什么事是Redis集群

到此,Redis Cluster 集群搭建完成

集群信息查看

Redis5的redis-cli新增系列集群運(yùn)維功能,查看命令詳情:

/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster help

什么事是Redis集群

命令參數(shù)具體作用可以參考官方文檔,下面會(huì)基于其中一些常用命令對(duì)集群進(jìn)行管理

  • 檢查節(jié)點(diǎn)狀態(tài)

/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster check 192.168.56.102:7000

什么事是Redis集群

  • 查看集群信息

/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster info 192.168.56.102:7000

什么事是Redis集群

集群擴(kuò)容

集群現(xiàn)在有3主3從,下面新增4個(gè)節(jié)點(diǎn)擴(kuò)容變成5主5從

  • 步驟1 啟動(dòng)新節(jié)點(diǎn) 創(chuàng)建4個(gè)Redis配置文件,端口號(hào)為7006~7009,然后啟動(dòng)節(jié)點(diǎn)(參考“集群搭建”的步驟3和步驟4)

  • 步驟2 新節(jié)點(diǎn)加入集群 設(shè)置4個(gè)節(jié)點(diǎn)分別加入已有redis集群,2個(gè)為主節(jié)點(diǎn),2個(gè)為從節(jié)點(diǎn)

/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7006 192.168.56.102:7005 
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7007 192.168.56.102:7005 

# 24e2c是節(jié)點(diǎn)7006的id,代表該節(jié)點(diǎn)加入集群并為7006的從節(jié)點(diǎn)
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7008 192.168.56.102:7005 --cluster-slave --cluster-master-id 24e2c369678952b07d95c0a4b49c2d7a7b2e2bf7 
# 24e2c是節(jié)點(diǎn)7007的id,代表該節(jié)點(diǎn)加入集群并為7007的從節(jié)點(diǎn)
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7009  192.168.56.102:7005 --cluster-slave --cluster-master-id ab0f74a19819a74238df7a510494e9418678cbe1

此時(shí)集群狀態(tài)如下,其中主節(jié)點(diǎn)7006和主節(jié)點(diǎn)7007還沒(méi)分配任何slot,在下面的步驟會(huì)進(jìn)行分配:

什么事是Redis集群

  • 步驟3 模擬slot重新平衡分配 基于rebalance命令,增加--cluster-simulat參數(shù),查看會(huì)遷移哪些slots,而不會(huì)真正執(zhí)行遷移操作

/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster rebalance 192.168.56.102:7000 --cluster-threshold 1 --cluster-use-empty-masters  --cluster-simulat

返回以下遷移信息: 什么事是Redis集群

  • 步驟4 執(zhí)行slot重新平衡分配 執(zhí)行rebalance命令,平衡集群節(jié)點(diǎn)slot數(shù)量,重新分配slot( 去掉--cluster-simulat)

/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster rebalance 192.168.56.102:7000 --cluster-threshold 1 --cluster-use-empty-masters

什么事是Redis集群

至此,集群擴(kuò)容完成,集群縮容的話(huà),需要基于reshard將需被下線(xiàn)的結(jié)點(diǎn)中的slot移到其他結(jié)點(diǎn),然后基于del-node命令刪除結(jié)點(diǎn)

到此,關(guān)于“什么事是Redis集群”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)
推薦閱讀:
  1. redis集群安裝
  2. redis集群

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI