您好,登錄后才能下訂單哦!
這篇文章主要介紹“什么事是Redis集群”,在日常操作中,相信很多人在什么事是Redis集群問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”什么事是Redis集群”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
2018年10月 Redis 發布了穩定版本的 5.0 版本,推出了各種新特性,其中一點是集群管理工具從基于Ruby的redis-trib.rb移植到基于C語言redis-cli中,方便集群的構建和管理
Redis Cluster集群運行至少需要包含3個主節點,實現高可用最少需要3主3從6個節點
以下步驟基于Redis 5.0.5版本,介紹如何在一臺 Linux 服務器上搭建有3主3從的6節點的 Redis集群
步驟1 創建安裝目錄
mkdir -p /data/project/redis-cluster
步驟2 下載源碼并解壓編譯
cd /data/project/redis-cluster wget http://download.redis.io/releases/redis-5.0.5.tar.gz tar xzf redis-5.0.5.tar.gz cd redis-5.0.5 make
執行make后,如果報錯“jemalloc/jemalloc.h:沒有那個文件或目錄”,可以改為用以下命令:
make MALLOC=libc
步驟3 創建6個Redis配置文件 6個配置文件不能在同一個目錄,下面Redis 6個節點分別安裝在7000~7005端口 首先創建配置文件目錄及文件,定義如下:
mkdir -p /data/project/redis-cluster/nodes/7000 mkdir -p /data/project/redis-cluster/nodes/7001 mkdir -p /data/project/redis-cluster/nodes/7002 mkdir -p /data/project/redis-cluster/nodes/7003 mkdir -p /data/project/redis-cluster/nodes/7004 mkdir -p /data/project/redis-cluster/nodes/7005 touch /data/project/redis-cluster/nodes/7000/redis.conf touch /data/project/redis-cluster/nodes/7001/redis.conf touch /data/project/redis-cluster/nodes/7002/redis.conf touch /data/project/redis-cluster/nodes/7003/redis.conf touch /data/project/redis-cluster/nodes/7004/redis.conf touch /data/project/redis-cluster/nodes/7005/redis.conf
redis.conf配置文件的內容為:
############################## 網絡 ############################## # 端口 port 7000 # 非保護模式,如果值為yes,則必須是 bind配置指定的ip的機器連接或者使用密碼連接 protected-mode no ############################## 通用 ############################## # 后臺運行 daemonize yes # 記錄redis進程pid pidfile /var/run/redis_7000.pid ############################## 集群 ############################## # 啟用集群模式 cluster-enabled yes cluster-config-file nodes_7000.conf # 集群節點如果在該超時時間(毫秒)內不可達,則認為節點處于故障狀態 cluster-node-timeout 5000 ############################## 持久化 ############################## # AOF, RDB持久化文件目錄 dir /data/project/redis-cluster/nodes # 開啟AOF持久化 appendonly yes # AOF文件名 appendfilename "appendonly_7000.aof" # 當目前aof文件大小超過上一次重寫的aof文件大小的百分之多少進行重寫 auto-aof-rewrite-percentage 100 # 設置允許重寫的最小aof文件大小,避免了達到約定百分比但尺寸仍然很小的情況還要重寫 auto-aof-rewrite-min-size 64mb # RDB文件名 dbfilename dump_7000.rdb
其中 port 、 pidfile、cluster-config-file、appendfilename、 dbfilename配置需要隨著節點的不同而調整
配置項說明可以參考redis-5.0.5/redis.conf,每一項都介紹得很詳細,推薦閱讀
步驟4 啟動節點
/data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7000/redis.conf /data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7001/redis.conf /data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7002/redis.conf /data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7003/redis.conf /data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7004/redis.conf /data/project/redis-cluster/redis-5.0.5/src/redis-server /data/project/redis-cluster/nodes/7005/redis.conf
ps -ef|grep redis,可以看到6個redis進程已啟動:
步驟5 啟動集群 使用如下命令啟動集群,IP地址自行替換:
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster create 192.168.56.102:7000 192.168.56.102:7001 192.168.56.102:7002 192.168.56.102:7003 192.168.56.102:7004 192.168.56.102:7005 --cluster-replicas 1
啟動成功信息如下:
到此,Redis Cluster 集群搭建完成
Redis5的redis-cli新增系列集群運維功能,查看命令詳情:
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster help
命令參數具體作用可以參考官方文檔,下面會基于其中一些常用命令對集群進行管理
檢查節點狀態
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster check 192.168.56.102:7000
查看集群信息
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster info 192.168.56.102:7000
集群現在有3主3從,下面新增4個節點擴容變成5主5從
步驟1 啟動新節點 創建4個Redis配置文件,端口號為7006~7009,然后啟動節點(參考“集群搭建”的步驟3和步驟4)
步驟2 新節點加入集群 設置4個節點分別加入已有redis集群,2個為主節點,2個為從節點
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7006 192.168.56.102:7005 /data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7007 192.168.56.102:7005 # 24e2c是節點7006的id,代表該節點加入集群并為7006的從節點 /data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7008 192.168.56.102:7005 --cluster-slave --cluster-master-id 24e2c369678952b07d95c0a4b49c2d7a7b2e2bf7 # 24e2c是節點7007的id,代表該節點加入集群并為7007的從節點 /data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster add-node 192.168.56.102:7009 192.168.56.102:7005 --cluster-slave --cluster-master-id ab0f74a19819a74238df7a510494e9418678cbe1
此時集群狀態如下,其中主節點7006和主節點7007還沒分配任何slot,在下面的步驟會進行分配:
步驟3 模擬slot重新平衡分配 基于rebalance命令,增加--cluster-simulat參數,查看會遷移哪些slots,而不會真正執行遷移操作
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster rebalance 192.168.56.102:7000 --cluster-threshold 1 --cluster-use-empty-masters --cluster-simulat
返回以下遷移信息:
步驟4 執行slot重新平衡分配 執行rebalance命令,平衡集群節點slot數量,重新分配slot( 去掉--cluster-simulat)
/data/project/redis-cluster/redis-5.0.5/src/redis-cli --cluster rebalance 192.168.56.102:7000 --cluster-threshold 1 --cluster-use-empty-masters
至此,集群擴容完成,集群縮容的話,需要基于reshard將需被下線的結點中的slot移到其他結點,然后基于del-node命令刪除結點
到此,關于“什么事是Redis集群”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。