首頁 >資料庫 >Redis >centos下怎麼搭建redis集群

centos下怎麼搭建redis集群

PHPz
PHPz轉載
2023-05-27 10:04:281576瀏覽

必備的工具:

redis-3.0.0.tar

redis-3.0.0.gem (ruby和redis介面)

分析:

首先,叢集數需要基數,這裡建構一個簡單的redis叢集(6個redis實例進行叢集)。

在一台伺服器上操作,因此只需6個不同的連接埠號碼。分別是:7001、7002、7003、7004、7005、7006。

步驟:

1、上傳redis-3.0.0.tar到伺服器(自己指定自己的軟體目錄),解壓縮redis-3.0.0.tar。

2、安裝c語言環境(安裝centos之後,自帶c語言環境)

yum install gcc-c++

3、進入redis-3.0.0目錄

make

4、安裝redis到/usr/local/redis目錄

make install prefix=/usr/local/redis

5、查看是否安裝成功(出現bin目錄即可)

centos下怎麼搭建redis集群

6、前端啟動redis(進入上圖的bin目錄)

./redis-server(開啟)

./redis-cli shutdown(關)

centos下怎麼搭建redis集群

7.後端啟動

需要將redis解壓縮之後的源碼包中(redis-3.0.0目錄下)的redis.conf檔拷貝到bin目錄下

修改redis.conf文件,將daemonize改為yes先要使用vim redis.conf

centos下怎麼搭建redis集群

#使用指令後端啟動redis

bin目錄下執行./redis-server redis.conf

查看是否啟動成功

centos下怎麼搭建redis集群

關閉後端啟動的方式:

./redis-cli shutdown

以上是單獨的redis安裝,接下來搭建集群!

安裝ruby

yum install ruby
yum install rubygems

將下列檔案上傳到linux系統

redis-3.0.0.gem (ruby和redis介面)

進入該目錄執行:gem install redis-3.0.0.gem

將redis-3.0.0套件下src目錄中的下列檔案拷貝到/usr/local/ redis/redis-cluster/

#前提:先新建一個redis-cluster目錄

centos下怎麼搭建redis集群

#搭建叢集最少也要需要3台主機,如果每台主機再配置一台從機的話,則最少需要6台機器。

埠設計如下:7001-7006

第一步:複製出一個7001機器

#進入/usr/local/redis/目錄執行cp bin ./redis- cluster/7001 –r

第二步:如果存在持久化文件,則刪除

rm -rf appendonly.aof dump.rdb

第三步:設定群集參數

centos下怎麼搭建redis集群

第四步:修改連接埠

centos下怎麼搭建redis集群

第五步:複製出7002-7006機器

給出我桌面系統下的目錄結構:

centos下怎麼搭建redis集群

接下來設定一鍵啟動全部redis或關閉redis群:

首先,新建一個文件,可以用vim開啟一個不存在的文件,然後保存就存在了。 (上圖的start-all.sh和shutdow-all.sh就是我新建的)

start-all.sh:

cd 7001
./redis-server redis.conf
cd ..
cd 7002
./redis-server redis.conf
cd ..
cd 7003
./redis-server redis.conf
cd ..
cd 7004
./redis-server redis.conf
cd ..
cd 7005
./redis-server redis.conf
cd ..
cd 7006
./redis-server redis.conf
cd ..

shutdow-all.sh:

cd 7001
./redis-cli -p 7001 shutdown
cd ..
cd 7002
./redis-cli -p 7002 shutdown
cd ..
cd 7003
./redis-cli -p 7003 shutdown
cd ..
cd 7004
./redis-cli -p 7004 shutdown
cd ..
cd 7005
./redis-cli -p 7005 shutdown
cd ..
cd 7006
./redis-cli -p 7006 shutdown
cd ..

接下來修改那兩個檔案權限,設定其為可啟動的腳本檔案

chmod u+x start-all.sh

chmod u+x shutdown-all.sh

接下來用ruby連接這幾個集群,進行管理

/redis-trib.rb create --replicas 1 192.168.78.133:7001 192.168.78.133:7002 192.168.78.133:7003 192.168.78.133:7004 19838.19838.133:7004 198383. :7006

出現:

connecting to node 192.168.242.137:7001: ok
connecting to node 192.168.242.137:7002: ok
connecting to node 192.168.242.137:7003: ok
connecting to node 192.168.242.137:7004: ok
connecting to node 192.168.242.137:7005: ok
connecting to node 192.168.242.137:7006: ok
>>> performing hash slots allocation on 6 nodes...
using 3 masters:
192.168.242.137:7001
192.168.242.137:7002
192.168.242.137:7003
adding replica 192.168.242.137:7004 to 192.168.242.137:7001
adding replica 192.168.242.137:7005 to 192.168.242.137:7002
adding replica 192.168.242.137:7006 to 192.168.242.137:7003
m: 8240cd0fe6d6f842faa42b0174fe7c5ddcf7ae24 192.168.242.137:7001
  slots:0-5460 (5461 slots) master
m: 4f52a974f64343fd9f1ee0388490b3c0647a4db7 192.168.242.137:7002
  slots:5461-10922 (5462 slots) master
m: cb7c5def8f61df2016b38972396a8d1f349208c2 192.168.242.137:7003
  slots:10923-16383 (5461 slots) master
s: 66adf006fed43b3b5e499ce2ff1949a756504a16 192.168.242.137:7004
  replicates 8240cd0fe6d6f842faa42b0174fe7c5ddcf7ae24
s: cbb0c9bc4b27dd85511a7ef2d01bec90e692793b 192.168.242.137:7005
  replicates 4f52a974f64343fd9f1ee0388490b3c0647a4db7
s: a908736eadd1cd06e86fdff8b2749a6f46b38c00 192.168.242.137:7006
  replicates cb7c5def8f61df2016b38972396a8d1f349208c2
can i set the above configuration? (type 'yes' to accept): yes
>>> nodes configuration updated
>>> assign a different config epoch to each node
>>> sending cluster meet messages to join the cluster
waiting for the cluster to join..
>>> performing cluster check (using node 192.168.242.137:7001)
m: 8240cd0fe6d6f842faa42b0174fe7c5ddcf7ae24 192.168.242.137:7001
  slots:0-5460 (5461 slots) master
m: 4f52a974f64343fd9f1ee0388490b3c0647a4db7 192.168.242.137:7002
  slots:5461-10922 (5462 slots) master
m: cb7c5def8f61df2016b38972396a8d1f349208c2 192.168.242.137:7003
  slots:10923-16383 (5461 slots) master
m: 66adf006fed43b3b5e499ce2ff1949a756504a16 192.168.242.137:7004
  slots: (0 slots) master
  replicates 8240cd0fe6d6f842faa42b0174fe7c5ddcf7ae24
m: cbb0c9bc4b27dd85511a7ef2d01bec90e692793b 192.168.242.137:7005
  slots: (0 slots) master
  replicates 4f52a974f64343fd9f1ee0388490b3c0647a4db7
m: a908736eadd1cd06e86fdff8b2749a6f46b38c00 192.168.242.137:7006
  slots: (0 slots) master
  replicates cb7c5def8f61df2016b38972396a8d1f349208c2
[ok] all nodes agree about slots configuration.
>>> check for open slots...
>>> check slots coverage...
[ok] all 16384 slots covered.

#則代表成功了!

測試一下,進入7001目錄執行:./redis-cli -h 192.168.242.137 -p 7001 –c

centos下怎麼搭建redis集群

#

以上是centos下怎麼搭建redis集群的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除