Redis分片集群的實(shí)現(xiàn)示例
前序:
Redis集群搭建直接一步到位:支持海量數(shù)據(jù)以及高并發(fā)寫
分片集群顧名思義,將數(shù)據(jù)分開存儲到Redis集群中,這樣能夠存儲更多的數(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、集群中有多個master,每個master保存不同分片數(shù)據(jù) ,解決海量數(shù)據(jù)存儲問題
2、每個master都可以有多個slave節(jié)點(diǎn) ,確保高可用
3、master之間通過ping監(jiān)測彼此健康狀態(tài) ,類似哨兵作用
4、客戶端請求可以訪問集群任意節(jié)點(diǎn),最終都會被轉(zhuǎn)發(fā)到數(shù)據(jù)所在節(jié)點(diǎn)
三主三從(一拖一):
三主六從(一拖二):
開始搭建:
1、先弄好一個節(jié)點(diǎn),然后再復(fù)制出來6個節(jié)點(diǎn),這樣子可以稍微快一些
分片集群中的Redis節(jié)點(diǎn)必須開啟集群模式,一般在配置文件中修改下面參數(shù)
這兩個密碼不要搞混了,作用不一樣
requirepass 登錄Redis的密碼
masterauth 鏈接集群的密碼
# 開啟集群模式 cluster-enabled yes # 集群模式的配置文件名稱,無需手動創(chuàng)建,由集群自動維護(hù) cluster-config-file nodes_6666.conf # 集群中節(jié)點(diǎn)之間心跳時間 cluster-node-timeout 5000
剩下的文件路徑,比如 .log .pid .data 等自行修改即可
2、將上邊修改好的 Redis 文件夾復(fù)制出來6份,每份用端口號后綴命名(如果有3臺機(jī)器更好,N個master就弄N臺機(jī)器),自行修改 confg 配置文件里的 .log .pid .data cluster-config-file 最好這些配置都攜帶端口號后綴
3、挨個啟動所有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
確定一下是否成功啟動:ps -ef | grep redis
4、構(gòu)建集群
進(jìn)入一個Redis的bin目錄,執(zhí)行命令,需要自行替換你自己的密碼以及IP和端口
./redis-cli -a 你的鏈接集群的密碼 --cluster create IP:6910 IP:6920 IP:6930 IP:6940 IP:6950 IP:6960 --cluster-replicas 1
這兩個密碼不要搞混了,作用不一樣
requirepass 登錄Redis的密碼
masterauth 鏈接集群的密碼
這里你的Redis分片集群就搭建好了
進(jìn)入集群查看信息:
1、進(jìn)入一個節(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
增加一個節(jié)點(diǎn)
1、將搭建過程中的Redis文件夾再復(fù)制一份,并修改里邊的config配置,IP 、port、.log .data .pid 等
2、啟動該節(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身份加入的,你可以將其修改為某個節(jié)點(diǎn)的從節(jié)點(diǎn)
redis-cli -c -h IP -p 新節(jié)點(diǎn)的端口 auth 你的鏈接集群的密碼 改變節(jié)點(diǎn)類型 cluster replicate 你的一個主節(jié)點(diǎn)的ID 查看集群節(jié)點(diǎn) CLUSTER NODES
移除一個節(jié)點(diǎn)
redis-cli -c -h IP -p 端口 auth 你鏈接集群的密碼 #查看節(jié)點(diǎn) CLUSTER NODES 刪除節(jié)點(diǎn) CLUSTER FORGET 需要刪除的節(jié)點(diǎn)的ID 檢查節(jié)點(diǎn)信息 CLUSTER NODES
模擬一個master節(jié)點(diǎn)掛掉了
1、把你的一個master實(shí)例 kill-9 一下,然后 cluster nodes 查看一個集群節(jié)點(diǎn)狀態(tài),你會發(fā)現(xiàn)你kill掉的那個節(jié)點(diǎn)狀態(tài)已經(jīng)變成 master,fail disconnected 同時這個master的從節(jié)點(diǎn)會升級為新的master
2、重新將kill掉的Redis實(shí)例啟動,然后 cluster nodes 查看集群節(jié)點(diǎn)狀態(tài),你會發(fā)現(xiàn)它成為了最新的那個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) #將一個或多個槽(slot)指派(assign)給當(dāng)前節(jié)點(diǎn) cluster addslots{<}slot{>}slot... #移除一個或多個槽對當(dāng)前節(jié)點(diǎn)的指派 cluster delslots{<}slot{>}[slot #移除指派給當(dāng)前節(jié)點(diǎn)的所有槽,讓當(dāng)前節(jié)點(diǎn)變成一個沒有指派任何槽的節(jié)點(diǎn) cluster flushslots #將槽s1ot指派給node id指定的節(jié)點(diǎn),如果槽已經(jīng)指派給另一個節(jié)點(diǎn) #那么先讓另一個節(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{>} #取消對槽slot的導(dǎo)入(import)或者遷移(migrate) cluster setslot{<}slot{>}stable 鍵 #計算鍵key應(yīng)該被放置在哪個槽上 cluster keyslot {<}key{>} # 返回槽slot目前包含的鍵值對數(shù)量 cluster countkeysinslot{<}slot{>} #返回count個slot槽中的鍵 cluster getkeysinslot{<}slot{>}{<}count{>}
到此這篇關(guān)于Redis分片集群的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Redis分片集群內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis 中spark參數(shù)executor-cores引起的異常解決辦法
這篇文章主要介紹了Redis 中spark參數(shù)executor-cores引起的異常解決辦法的相關(guān)資料,需要的朋友可以參考下2017-03-03Redis核心原理與實(shí)踐之字符串實(shí)現(xiàn)原理
這本書深入地分析了Redis常用特性的內(nèi)部機(jī)制與實(shí)現(xiàn)方式,內(nèi)容源自對Redis源碼的分析,并從中總結(jié)出設(shè)計思路、實(shí)現(xiàn)原理。對Redis字符串實(shí)現(xiàn)原理相關(guān)知識感興趣的朋友一起看看吧2021-09-09Redis事務(wù)機(jī)制與Springboot項目中的使用方式
Redis事務(wù)機(jī)制允許將多個命令打包在一起,作為一個原子操作來執(zhí)行,開啟事務(wù)使用MULTI命令,執(zhí)行事務(wù)使用EXEC命令,取消事務(wù)使用DISCARD命令,監(jiān)視一個或多個鍵使用WATCH命令,Redis事務(wù)的核心思想是將多個命令放入一個隊列中2025-03-03NestJS+Redis實(shí)現(xiàn)緩存步驟詳解
這篇文章主要介紹了NestJS+Redis實(shí)現(xiàn)緩存,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08Redis中5種數(shù)據(jù)結(jié)構(gòu)的使用場景介紹
這篇文章主要介紹了Redis中5種數(shù)據(jù)結(jié)構(gòu)的使用場景介紹,本文對Redis中的5種數(shù)據(jù)類型String、Hash、List、Set、Sorted Set做了講解,需要的朋友可以參考下2014-09-09