Redis分片集群的實(shí)現(xiàn)示例
前序:
Redis集群搭建直接一步到位:支持海量數(shù)據(jù)以及高并發(fā)寫
分片集群顧名思義,將數(shù)據(jù)分開存儲(chǔ)到Redis集群中,這樣能夠存儲(chǔ)更多的數(shù)據(jù),避免浪費(fèi)資源,基礎(chǔ)搭建如:三主三從(一拖一)、三主六從(一拖二),本次搭建采用一拖一,一拖二情況可根據(jù)文末圖文介紹進(jìn)行添加從節(jié)點(diǎn)即可
cluster不能選擇db,只能默認(rèn)db為0,所以select切庫相當(dāng)于是不能使用的。
cluster不能選擇db,只能默認(rèn)db為0,所以select切庫相當(dāng)于是不能使用的。
cluster不能選擇db,只能默認(rèn)db為0,所以select切庫相當(dāng)于是不能使用的。
部署圖:
分片集群特征:
1、集群中有多個(gè)master,每個(gè)master保存不同分片數(shù)據(jù) ,解決海量數(shù)據(jù)存儲(chǔ)問題
2、每個(gè)master都可以有多個(gè)slave節(jié)點(diǎn) ,確保高可用
3、master之間通過ping監(jiān)測(cè)彼此健康狀態(tài) ,類似哨兵作用
4、客戶端請(qǐng)求可以訪問集群任意節(jié)點(diǎn),最終都會(huì)被轉(zhuǎn)發(fā)到數(shù)據(jù)所在節(jié)點(diǎn)
三主三從(一拖一):

三主六從(一拖二):

開始搭建:
1、先弄好一個(gè)節(jié)點(diǎn),然后再復(fù)制出來6個(gè)節(jié)點(diǎn),這樣子可以稍微快一些
分片集群中的Redis節(jié)點(diǎn)必須開啟集群模式,一般在配置文件中修改下面參數(shù)
這兩個(gè)密碼不要搞混了,作用不一樣
requirepass 登錄Redis的密碼
masterauth 鏈接集群的密碼
# 開啟集群模式 cluster-enabled yes # 集群模式的配置文件名稱,無需手動(dòng)創(chuàng)建,由集群自動(dòng)維護(hù) cluster-config-file nodes_6666.conf # 集群中節(jié)點(diǎn)之間心跳時(shí)間 cluster-node-timeout 5000
剩下的文件路徑,比如 .log .pid .data 等自行修改即可
2、將上邊修改好的 Redis 文件夾復(fù)制出來6份,每份用端口號(hào)后綴命名(如果有3臺(tái)機(jī)器更好,N個(gè)master就弄N臺(tái)機(jī)器),自行修改 confg 配置文件里的 .log .pid .data cluster-config-file 最好這些配置都攜帶端口號(hào)后綴
3、挨個(gè)啟動(dòng)所有Redis節(jié)點(diǎn)服務(wù)
./redis-server ../conf/redis_6910.conf ./redis-server ../conf/redis_6920.conf ./redis-server ../conf/redis_6930.conf ./redis-server ../conf/redis_6940.conf ./redis-server ../conf/redis_6950.conf ./redis-server ../conf/redis_6960.conf
確定一下是否成功啟動(dòng):ps -ef | grep redis

4、構(gòu)建集群
進(jìn)入一個(gè)Redis的bin目錄,執(zhí)行命令,需要自行替換你自己的密碼以及IP和端口
./redis-cli -a 你的鏈接集群的密碼 --cluster create IP:6910 IP:6920 IP:6930 IP:6940 IP:6950 IP:6960 --cluster-replicas 1
這兩個(gè)密碼不要搞混了,作用不一樣
requirepass 登錄Redis的密碼
masterauth 鏈接集群的密碼
這里你的Redis分片集群就搭建好了
進(jìn)入集群查看信息:
1、進(jìn)入一個(gè)節(jié)點(diǎn)的Redis的bin目錄,執(zhí)行命令
./redis-cli -c -h 你的IP -p 6910
2、在提示框里輸入你鏈接集群的密碼
auth 你的鏈接集群的密碼
這樣你就進(jìn)來了,下邊是一些基本命令
3、查看集群基本信息
cluster info
4、查看集群節(jié)點(diǎn)信息
cluster nodes
增加一個(gè)節(jié)點(diǎn)
1、將搭建過程中的Redis文件夾再復(fù)制一份,并修改里邊的config配置,IP 、port、.log .data .pid 等
2、啟動(dòng)該節(jié)點(diǎn)
3、進(jìn)入bin目錄執(zhí)行命令使之加入集群
./redis-cli -c -h IP -p 端口 auth 你鏈接集群的密碼 添加節(jié)點(diǎn) cluster meet IP 新節(jié)點(diǎn)的端口 查看節(jié)點(diǎn)信息 cluster nodes
新加入的節(jié)點(diǎn)都是以master身份加入的,你可以將其修改為某個(gè)節(jié)點(diǎn)的從節(jié)點(diǎn)
redis-cli -c -h IP -p 新節(jié)點(diǎn)的端口 auth 你的鏈接集群的密碼 改變節(jié)點(diǎn)類型 cluster replicate 你的一個(gè)主節(jié)點(diǎn)的ID 查看集群節(jié)點(diǎn) CLUSTER NODES
移除一個(gè)節(jié)點(diǎn)
redis-cli -c -h IP -p 端口 auth 你鏈接集群的密碼 #查看節(jié)點(diǎn) CLUSTER NODES 刪除節(jié)點(diǎn) CLUSTER FORGET 需要?jiǎng)h除的節(jié)點(diǎn)的ID 檢查節(jié)點(diǎn)信息 CLUSTER NODES
模擬一個(gè)master節(jié)點(diǎn)掛掉了
1、把你的一個(gè)master實(shí)例 kill-9 一下,然后 cluster nodes 查看一個(gè)集群節(jié)點(diǎn)狀態(tài),你會(huì)發(fā)現(xiàn)你kill掉的那個(gè)節(jié)點(diǎn)狀態(tài)已經(jīng)變成 master,fail disconnected 同時(shí)這個(gè)master的從節(jié)點(diǎn)會(huì)升級(jí)為新的master
2、重新將kill掉的Redis實(shí)例啟動(dòng),然后 cluster nodes 查看集群節(jié)點(diǎn)狀態(tài),你會(huì)發(fā)現(xiàn)它成為了最新的那個(gè)master的slave(這一步就是故障恢復(fù))
命令匯總
集群
#打印集群的信息
cluster info
#列出集群當(dāng)前已知的所有節(jié)點(diǎn)(node),以及這些節(jié)點(diǎn)的相關(guān)信息
cluster nodes
節(jié)點(diǎn)
#將ip和port所指定的節(jié)點(diǎn)添加到集群當(dāng)中,讓它成為集群的一份子
cluster meet IP PORT
#從集群中移除node id指定的節(jié)點(diǎn)
cluster forget 節(jié)點(diǎn)ID
#將當(dāng)前節(jié)點(diǎn)設(shè)置為node id指定的節(jié)點(diǎn)的從節(jié)點(diǎn)
cluster replicate 節(jié)點(diǎn)ID
#將節(jié)點(diǎn)的配置文件保存到硬盤里面
cluster saveconfig
槽(slot)
#將一個(gè)或多個(gè)槽(slot)指派(assign)給當(dāng)前節(jié)點(diǎn)
cluster addslots{<}slot{>}slot...
#移除一個(gè)或多個(gè)槽對(duì)當(dāng)前節(jié)點(diǎn)的指派
cluster delslots{<}slot{>}[slot
#移除指派給當(dāng)前節(jié)點(diǎn)的所有槽,讓當(dāng)前節(jié)點(diǎn)變成一個(gè)沒有指派任何槽的節(jié)點(diǎn)
cluster flushslots
#將槽s1ot指派給node id指定的節(jié)點(diǎn),如果槽已經(jīng)指派給另一個(gè)節(jié)點(diǎn)
#那么先讓另一個(gè)節(jié)點(diǎn)刪除該槽,然后再進(jìn)行指派
cluster setslot{<}slot{>}node{<}node id{>}
#將本節(jié)點(diǎn)的槽slot遷移到node id指定的節(jié)點(diǎn)中
cluster setslot{<}slot{>}migrating{<}node id{>}
#從node_id指定的節(jié)點(diǎn)中導(dǎo)入槽slot到本節(jié)點(diǎn)
cluster setslot{<}slot{>}importing{<}node id{>}
#取消對(duì)槽slot的導(dǎo)入(import)或者遷移(migrate)
cluster setslot{<}slot{>}stable
鍵
#計(jì)算鍵key應(yīng)該被放置在哪個(gè)槽上
cluster keyslot {<}key{>}
# 返回槽slot目前包含的鍵值對(duì)數(shù)量
cluster countkeysinslot{<}slot{>}
#返回count個(gè)slot槽中的鍵
cluster getkeysinslot{<}slot{>}{<}count{>}到此這篇關(guān)于Redis分片集群的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Redis分片集群內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
redis通過6379端口無法連接服務(wù)器(redis-server.exe閃退)
這篇文章主要介紹了redis通過6379端口無法連接服務(wù)器(redis-server.exe閃退),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
redis中事務(wù)機(jī)制及樂觀鎖的實(shí)現(xiàn)
這篇文章主要介紹了redis中事務(wù)機(jī)制及樂觀鎖的相關(guān)內(nèi)容,通過事務(wù)的執(zhí)行分析Redis樂觀鎖,具有一定參考價(jià)值,需要的朋友可以了解下。2017-10-10
深入理解Redis內(nèi)存回收和內(nèi)存淘汰機(jī)制
Redis使用多種過期策略和內(nèi)存淘汰機(jī)制來管理內(nèi)存,本文主要介紹了深入理解Redis內(nèi)存回收和內(nèi)存淘汰機(jī)制, 具有一定的參考價(jià)值,感興趣的可以了解一下2024-06-06
Redis實(shí)現(xiàn)好友關(guān)注的示例代碼
本文主要介紹了Redis實(shí)現(xiàn)好友關(guān)注的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01

