這篇文章為大家帶來了關於Redis的相關知識,其中主要整理了叢集操作的相關問題,包括了增加redis實例、配置8007為主節點、配置8008為8007的從節點等等內容,下面一起來看一下,希望對大家有幫助。
推薦學習:Redis影片教學
基於已有一定基礎,這裡建立一個基礎版本三主三從,架構如下
/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節點,
這三個master節點儲存的所有hash槽組成redis叢集的儲存槽位,slave點是每個主節點的備份從節點,不顯示儲存槽位。
我們在原始叢集基礎上再增加一主(8007)一從(8008),增加節點後的叢集參考下圖,新增節點以虛線框表示
在/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
用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
/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
用del-node删除从节点8008,指定删除节点ip和端口,以及节点id(红色为8008节点id) 再次查看集群状态,如下图所示,8008这个slave节点已经移除,并且该节点的redis服务也已被停止
因为主节点的里面是有分配了hash槽的,所以我们这里必须先把8007里的hash槽放入到其他的可用主节点中去,然后再进行移除节点操作,不然会出现数据丢失问题(目前只能把master的数据迁移到一个节点上,暂时做不了平均分配功能),执行命令如下: 迁移验证:会发现8007下面已经没有任何hash槽了,证明迁移成功!
用del-node命令删除8007主节点即可 查看最终集群状态,发现一切恢复如初,至此水平扩展结束
推荐学习:Redis视频教程 2.4、删除8080从节点[不删除四主四从]
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster del‐node 192.168.0.61:8008 a1cfe35722d151cf70585cee212755653 93c0956
2.5、删除8007主节点[不删除四主四从]
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster reshard 192.168.0.61:8007
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster del‐node 192.168.0.61:8007 2728a594a0498e98e4b83a537e19f9a0a 3790f38
以上是Redis集群操作實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!