首先了解下RedisCluster集群原理
搭建方案介紹
安裝部署任何一個應用其實都很簡單,只要安裝步驟一步一步來就行了。下面說一下 Redis 集群搭建規划,由於集群至少需要6個節點(3主3從模式),所以,沒有這么多機器給我玩,我本地也起不了那么多虛擬機(電腦太爛),現在計划是在一台機器上模擬一個集群,當然,這和生產環境的集群搭建沒本質區別。
搭建設計:
本博客計划集群,Redis 節點的端口號為 9001-9006 ,端口號即集群下各實例文件夾。數據存放在端口號/data 文件夾中。多主多備一共6台。
參考單機版:https://www.cnblogs.com/toov5/p/9884260.html
注意: 但是,第五步時候要把bind 改為本地ip 並且不要設置密碼!requiredpass 博主在寫教程時候就搞了密碼!
當前服務器的ip地址:
然后: 我們計划集群中 Redis 節點的端口號為 9001-9006 ,端口號即集群下各實例文件夾。數據存放在 端口號/data 文件夾中。
mkdir /usr/local/redis-cluster
cd redis-cluster/
mkdir -p 9001/data 9002/data 9003/data 9004/data 9005/data 9006/data
然后,復制腳本。在 /usr/local/redis-cluster 下創建 bin 文件夾,用來存放集群運行腳本,並把安裝好的 Redis 的 src 路徑下的運行腳本拷貝過來。看命令:
cd /usr/local/redis-cluster mkdir bin
cd /home/redis/redis-3.2.9/src
cp mkreleasehdr.sh redis-benchmark redis-check-aof redis-cli redis-server redis-trib.rb /usr/local/redis-cluster/bin
然后,復制一個新 Redis 實例。我們現在從已安裝好的 Redis 中復制一個新的實例到 9001 文件夾,並修改 redis.conf 配置。
cp -r /usr/local/redis /usr/local/redis-cluster/9001
cd /usr/local/redis-cluster/9001/redis/etc
注意,修改 redis.conf 配置和單點唯一區別是下圖部分,其余還是常規的這幾項:
port 9001(每個節點的端口號)
daemonize yes
bind 192.168.119.131(綁定當前機器 IP)
dir /usr/local/redis-cluster/9001/data/(數據文件存放位置,,自己加到最后一行 快捷鍵 shift+g)
pidfile /var/run/redis_9001.pid(pid 9001和port要對應)
cluster-enabled yes(啟動集群模式)
cluster-config-file nodes9001.conf(9001和port要對應)
cluster-node-timeout 15000
appendonly yes //開啟aof
然后,再復制出五個新 Redis 實例。我們已經完成了一個節點了,其實接下來就是機械化的再完成另外五個節點,其實可以這么做:把 9001 實例 復制到另外五個文件夾中,唯一要修改的就是 redis.conf 中的所有和端口的相關的信息即可,其實就那么四個位置。開始操作
cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9002
cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9003
cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9004
cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9005
cp -rf /usr/local/redis-cluster/9001/* /usr/local/redis-cluster/9006
然后,修改 9002-9006 的 redis.conf 文件。其實非常簡單了,你通過搜索會發現其實只有四個點需要修改,我們全局替換下吧,進入相應的節點文件夾,做替換就好了。命令非常簡單
vi /usr/local/redis-cluster/9002/redis/etc/redis.conf
%s/9001/9002
vi /usr/local/redis-cluster/9003/redis/etc/redis.conf
%s/9001/9003
vi /usr/local/redis-cluster/9004/redis/etc/redis.conf
%s/9001/9004
vi /usr/local/redis-cluster/9005/redis/etc/redis.conf
%s/9001/9005
vi /usr/local/redis-cluster/9006/redis/etc/redis.conf
%s/9001/9006
其實,我們是替換了這幾個:
port 9002
dir /usr/local/redis-cluster/9002/data/
cluster-config-file nodes-9002.conf
pidfile /var/run/redis_9002.pid
下面我們來啟動:
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/9001/redis/etc/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/9002/redis/etc/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/9003/redis/etc/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/9004/redis/etc/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/9005/redis/etc/redis.conf
/usr/local/redis/bin/redis-server /usr/local/redis-cluster/9006/redis/etc/redis.conf