首頁  >  文章  >  資料庫  >  Redis集群操作實例詳解

Redis集群操作實例詳解

WBOY
WBOY轉載
2022-06-23 12:24:122174瀏覽

這篇文章為大家帶來了關於Redis的相關知識,其中主要整理了叢集操作的相關問題,包括了增加redis實例、配置8007為主節點、配置8008為8007的從節點等等內容,下面一起來看一下,希望對大家有幫助。

Redis集群操作實例詳解

推薦學習:Redis影片教學

基於已有一定基礎,這裡建立一個基礎版本三主三從,架構如下

#1、啟動叢集##
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8001/redis.conf 
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8002/redis.conf 
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8003/redis.conf 
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8004/redis.conf 
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8005/redis.conf 
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8006/redis.conf

查看叢集狀態:cluster nodes

從上圖可以看出,整個叢集運作正常,三個master節點和三個slave節點,

  • 8001埠的實例節點儲存0-5460這些hash槽,
  • 8002埠的實例節點儲存5461-10922這些hash槽,
  • 8003埠的實例節點儲存10923-16383這些hash槽,

這三個master節點儲存的所有hash槽組成redis叢集的儲存槽位,slave點是每個主節點的備份從節點,不顯示儲存槽位。

2、叢集操作

        我們在原始叢集基礎上再增加一主(8007)一從(8008),增加節點後的叢集參考下圖,新增節點以虛線框表示

2.1、增加redis實例

        在/usr/local/redis-cluster下建立8007和8008資料夾,並拷貝8001資料夾下的redis.conf檔案到8007和8008這兩個資料夾下

mkdir 8007 8008 
cd 8001
cp redis.conf /usr/local/redis‐cluster/8007/ 
cp redis.conf /usr/local/redis‐cluster/8008/
 
# 修改8007文件夹下的redis.conf配置文件
vim /usr/local/redis‐cluster/8007/redis.conf 
# 修改如下内容:
port:8007 
dir /usr/local/redis‐cluster/8007/
cluster‐config‐file nodes‐8007.conf 

# 修改8008文件夹下的redis.conf配置文件
vim /usr/local/redis‐cluster/8008/redis.conf
# 修改内容如下:
port:8008
dir /usr/local/redis‐cluster/8008/
cluster‐config‐file nodes‐8008.conf

# 启动8007和8008俩个服务并查看服务状态
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8007/redis.conf
/usr/local/redis‐5.0.3/src/redis‐server /usr/local/redis‐cluster/8008/redis.conf

ps ‐el | grep redis

 2.2、設定8007為主節點

用add-node指令新增一個主節點8007 (master),前面的ip:port為新增節點,後面的ip:port為已知存在節點,看到日誌最後有"[OK] New node added correctly"提示代表新節點加入成功

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster add‐node 192.168.0.61:8007 192.168.0.61:8001

查看叢集狀態 

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐c ‐h 192.168.0.61 ‐p 8001

192.168.0.61:8001> cluster nodes

如下: 

注意:當添加節點成功以後,新增的節點不會有任何數據,因為它還沒有分配任何的slot(hash槽),我們需要為新節點手動分配hash槽

使用redis-cli指令為8007指派hash槽,找到叢集中的任一個主節點,對其進行重新分片工作

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster reshard 192.168.0.61:8001

2.3、設定8008為8007的從節點

##新增從節點8008到叢集中去並查看叢集狀態

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster add‐node 192.168.0.61:8008 192.168.0.61:8001

 如下:

#如圖所示,還是一個master節點,沒有被分配任何的hash槽。

原因:我們需要執行replicate指令來指定目前節點(從節點)的主節點id為哪個,首先需要連接新加的8008節點的客戶端,然後使用叢集指令進行操作,把目前的8008(slave)節點指定到一個主節點下(這裡使用之前建立的8007主節點)

執行指令

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐c ‐h 192.168.0.61 ‐p 8008 

192.168.0.61:8008> cluster replicate 2728a594a0498e98e4b83a537e19f9a0a3790f38 #后面这串id为8007的节点id

查看叢集狀態,8008節點已成功新增為8007節點的從節點

 2.4、删除8080从节点[不删除四主四从]

用del-node删除从节点8008,指定删除节点ip和端口,以及节点id(红色为8008节点id)

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster del‐node 192.168.0.61:8008 a1cfe35722d151cf70585cee212755653 93c0956

再次查看集群状态,如下图所示,8008这个slave节点已经移除,并且该节点的redis服务也已被停止

 2.5、删除8007主节点[不删除四主四从]

因为主节点的里面是有分配了hash槽的,所以我们这里必须先把8007里的hash槽放入到其他的可用主节点中去,然后再进行移除节点操作,不然会出现数据丢失问题(目前只能把master的数据迁移到一个节点上,暂时做不了平均分配功能),执行命令如下:

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster reshard 192.168.0.61:8007

迁移验证:会发现8007下面已经没有任何hash槽了,证明迁移成功!

 用del-node命令删除8007主节点即可

/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster del‐node 192.168.0.61:8007 2728a594a0498e98e4b83a537e19f9a0a 3790f38

查看最终集群状态,发现一切恢复如初,至此水平扩展结束

推荐学习:Redis视频教程

以上是Redis集群操作實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除