天天看點

檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容

來源:https://juejin.im/post/5dae4cad518825208707f858

叢集搭建

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 建立安裝目錄
  • 步驟2 下載下傳源碼并解壓編譯

執行make後,如果報錯“jemalloc/jemalloc.h:沒有那個檔案或目錄”,可以改為用以下指令:

  • 步驟3 建立6個Redis配置檔案 6個配置檔案不能在同一個目錄,下面Redis 6個節點分别安裝在7000~7005端口 首先建立配置檔案目錄及檔案,定義如下:

redis.conf配置檔案的内容為:

其中 port 、 pidfile、cluster-config-file、appendfilename、 dbfilename配置需要随着節點的不同而調整

配置項說明可以參考redis-5.0.5/redis.conf,每一項都介紹得很詳細,推薦閱讀

  • 步驟4 啟動節點

ps -ef|grep redis,可以看到6個redis程序已啟動:

檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容
  • 步驟5 啟動叢集 使用如下指令啟動叢集,IP位址自行替換:

啟動成功資訊如下:

檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容

到此,Redis Cluster 叢集搭建完成

叢集資訊檢視

Redis5的redis-cli新增系列叢集運維功能,檢視指令詳情:

檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容

指令參數具體作用可以參考官方文檔,下面會基于其中一些常用指令對叢集進行管理

  • 檢查節點狀态
檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容
  • 檢視叢集資訊
檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容

叢集擴容

叢集現在有3主3從,下面新增4個節點擴容變成5主5從

  • 步驟1 啟動新節點 建立4個Redis配置檔案,端口号為7006~7009,然後啟動節點(參考“叢集搭建”的步驟3和步驟4)
  • 步驟2 新節點加入叢集 設定4個節點分别加入已有redis叢集,2個為主節點,2個為從節點

此時叢集狀态如下,其中主節點7006和主節點7007還沒配置設定任何slot,在下面的步驟會進行配置設定:

檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容
  • 步驟3 模拟slot重新平衡配置設定 基于rebalance指令,增加--cluster-simulat參數,檢視會遷移哪些slots,而不會真正執行遷移操作

傳回以下遷移資訊:

檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容
  • 步驟4 執行slot重新平衡配置設定 執行rebalance指令,平衡叢集節點slot數量,重新配置設定slot( 去掉--cluster-simulat)
檢視redis版本_玩轉Redis叢集,支撐微網誌億級社交平台叢集搭建叢集資訊檢視叢集擴容

至此,叢集擴容完成,叢集縮容的話,需要基于reshard将需被下線的結點中的slot移到其他結點,然後基于del-node指令删除結點