本篇內(nèi)容介紹了“redis集群操作的方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
為忠縣等地區(qū)用戶提供了全套網(wǎng)頁設計制作服務,及忠縣網(wǎng)站建設行業(yè)解決方案。主營業(yè)務為成都網(wǎng)站制作、網(wǎng)站建設、外貿(mào)網(wǎng)站建設、忠縣網(wǎng)站設計,以傳統(tǒng)方式定制建設網(wǎng)站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!
基于已有一定基礎,這里搭建一個基礎版本三主三從,架構如下
/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
查看集群狀態(tài):cluster nodes
從上圖可以看出,整個集群運行正常,三個master節(jié)點和三個slave節(jié)點,
8001端口的實例節(jié)點存儲0-5460這些hash槽,
8002端口的實例節(jié)點存儲5461-10922這些hash槽,
8003端口的實例節(jié)點存儲10923-16383這些hash槽,
這三個master節(jié)點存儲的所有hash槽組成 redis集群的存儲槽位,slave點是每個主節(jié)點的備份從節(jié)點,不顯示存儲槽位。
我們在原始集群基礎上再增加一主(8007)一從(8008),增加節(jié)點后的集群參見下圖,新增節(jié)點用虛線框表示
在/usr/local/redis-cluster下創(chuàng)建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 # 修改如下內(nèi)容: 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 # 修改內(nèi)容如下: port:8008 dir /usr/local/redis‐cluster/8008/ cluster‐config‐file nodes‐8008.conf # 啟動8007和8008倆個服務并查看服務狀態(tài) /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命令新增一個主節(jié)點8007(master),前面的ip:port為新增節(jié)點,后面的ip:port為已知存在節(jié)點,看到日志最后有"[OK] New node added correctly"提示代表新節(jié)點加入成功
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster add‐node 192.168.0.61:8007 192.168.0.61:8001
查看集群狀態(tài)
/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
如下所示:
注意:當添加節(jié)點成功以后,新增的節(jié)點不會有任何數(shù)據(jù),因為它還沒有分配任何的slot(hash槽),我們需要為新節(jié)點手工分配hash槽
使用redis-cli命令為8007分配hash槽,找到集群中的任意一個主節(jié)點,對其進行重新分片工作
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster reshard 192.168.0.61:8001
添加從節(jié)點8008到集群中去并查看集群狀態(tài)
/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節(jié)點,沒有被分配任何的hash槽。
原因:我們需要執(zhí)行replicate命令來指定當前節(jié)點(從節(jié)點)的主節(jié)點id為哪個,首先需要連接新加的8008節(jié)點的客戶端,然后使用集群命令進行操作,把當前的8008(slave)節(jié)點指定到一個主節(jié)點下(這里使用之前創(chuàng)建的8007主節(jié)點)
執(zhí)行指令
/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的節(jié)點id
查看集群狀態(tài),8008節(jié)點已成功添加為8007節(jié)點的從節(jié)點
用del-node刪除從節(jié)點8008,指定刪除節(jié)點ip和端口,以及節(jié)點id(紅色為8008節(jié)點id)
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster del‐node 192.168.0.61:8008 a1cfe35722d151cf70585cee212755653 93c0956
再次查看集群狀態(tài),如下圖所示,8008這個slave節(jié)點已經(jīng)移除,并且該節(jié)點的redis服務也已被停止
因為主節(jié)點的里面是有分配了hash槽的,所以我們這里必須先把8007里的hash槽放入到其他的可用主節(jié)點中去,然后再進行移除節(jié)點操作,不然會出現(xiàn)數(shù)據(jù)丟失問題(目前只能把master的數(shù)據(jù)遷移到一個節(jié)點上,暫時做不了平均分配功能),執(zhí)行命令如下:
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster reshard 192.168.0.61:8007
遷移驗證:會發(fā)現(xiàn)8007下面已經(jīng)沒有任何hash槽了,證明遷移成功!
用del-node命令刪除8007主節(jié)點即可
/usr/local/redis‐5.0.3/src/redis‐cli ‐a user ‐‐cluster del‐node 192.168.0.61:8007 2728a594a0498e98e4b83a537e19f9a0a 3790f38
查看最終集群狀態(tài),發(fā)現(xiàn)一切恢復如初,至此水平擴展結束
“Redis集群操作的方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!