用redis-trib.rb搭建redis集群-創(chuàng)新互聯(lián)

用redis-trib.rb搭建集群【常用方法】

創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于做網(wǎng)站、網(wǎng)站制作、穆棱網(wǎng)絡(luò)推廣、微信小程序開發(fā)、穆棱網(wǎng)絡(luò)營銷、穆棱企業(yè)策劃、穆棱品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們大的嘉獎(jiǎng);創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供穆棱建站搭建服務(wù),24小時(shí)服務(wù)熱線:13518219792,官方網(wǎng)址:muchs.cn
  • redis-trib.rb 是采用Ruby實(shí)現(xiàn)的redis集群管理工具;

  • 內(nèi)部通過Cluster相關(guān)命令進(jìn)行簡化集群創(chuàng)建、檢查、槽喬伊和均衡等常見運(yùn)維操作;

  • 使用之前需要安裝Ruby依賴環(huán)境

1、Ruby環(huán)境準(zhǔn)備
https://cache.ruby-lang.org/pub/ruby/2.3/【下載網(wǎng)址】

-- 下載ruby ---
cd /soft/tools
wget https://cache.ruby-lang.org/pub/ruby/2.3/ruby-2.3.4.tar.gz

-- 安裝ruby ---
tar zxf ruby-2.3.4.tar.gz
cd ruby-2.3.4
./configure --prefix=/soft/ruby-2.3.4
make
make install
ln -s /soft/ruby-2.3.4 /soft/ruby
cd /soft/ruby
cp bin/ruby /usr/local/bin/
cp bin/gem /usr/local/bin/
[root@lbl ruby]# ll /usr/local/bin/{ruby,gem}
-rwxr-xr-x. 1 root root      548 Apr 21 00:42 /usr/local/bin/gem
-rwxr-xr-x. 1 root root 22306743 Apr 21 00:42 /usr/local/bin/ruby

-- 安裝rubygem redis依賴 ---
wget http://rubygems.org/downloads/redis-3.3.0.gem
gem install -l redis-3.3.0.gem
gem list --check redis gem

-- 安裝redis-rb管理工具 ---
[root@test ruby]# cp /soft/tools/redis-3.2.0/src/redis-trib.rb /usr/local/bin/
[root@test ruby]# ll /usr/local/bin/{ruby,gem,*.rb}
-rwxr-xr-x. 1 root root      548 Apr 16 10:05 /usr/local/bin/gem
-rwxr-xr-x. 1 root root    60578 Apr 16 10:07 /usr/local/bin/redis-trib.rb
-rwxr-xr-x. 1 root root 22306727 Apr 16 10:05 /usr/local/bin/ruby
2、準(zhǔn)備節(jié)點(diǎn)
-- 主節(jié)點(diǎn)
redis-server /soft/redis/cluster/7000/redis.conf &
redis-server /soft/redis/cluster/7100/redis.conf &
redis-server /soft/redis/cluster/7200/redis.conf &
-- 從節(jié)點(diǎn)
redis-server /soft/redis/cluster/7001/redis.conf &
redis-server /soft/redis/cluster/7101/redis.conf &
redis-server /soft/redis/cluster/7201/redis.conf &
3、創(chuàng)建集群

啟動(dòng)好6個(gè)節(jié)點(diǎn)之后,使用redis-trib.rb create命令完成節(jié)點(diǎn)握手和槽分配過程:

注意:指定 主從節(jié)點(diǎn)時(shí),前三個(gè)為主節(jié)點(diǎn);后三個(gè)為對應(yīng)從節(jié)點(diǎn)

[root@test cluster]# redis-trib.rb create --replicas 1 127.0.0.1:7000 127.0.0.1:7001 127.0.0.1:7100 127.0.0.1:7101 127.0.0.1:7200 127.0.0.1:7300
>>> Creating cluster
>>> Performing hash slots allocation on 6 nodes...
Using 3 masters:
127.0.0.1:7000
127.0.0.1:7001
127.0.0.1:7100
Adding replica 127.0.0.1:7101 to 127.0.0.1:7000
Adding replica 127.0.0.1:7200 to 127.0.0.1:7001
Adding replica 127.0.0.1:7300 to 127.0.0.1:7100
M: b70ce6df43039cd8ef2004a031851668dfe51982 127.0.0.1:7000
   slots:0-5460 (5461 slots) master
M: 3300b8f899d7f369d7095025954f2069857801c0 127.0.0.1:7001
   slots:5461-10922 (5462 slots) master
M: 085d2851ef195428786f7df14a2c00fedb6ccec9 127.0.0.1:7100
   slots:10923-16383 (5461 slots) master
S: 97cf943c9fac35520fdd9426e344f7b7cc390fb8 127.0.0.1:7101
   replicates b70ce6df43039cd8ef2004a031851668dfe51982
S: e2fae64bbac1fc28d66c4cb21c5be95be4ba8953 127.0.0.1:7200
   replicates 3300b8f899d7f369d7095025954f2069857801c0
S: 5207520b05fd05240a56d132bf90fa4e9dde97cb 127.0.0.1:7300
   replicates 085d2851ef195428786f7df14a2c00fedb6ccec9
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 127.0.0.1:7000)
M: b70ce6df43039cd8ef2004a031851668dfe51982 127.0.0.1:7000
   slots:0-5460 (5461 slots) master
M: 3300b8f899d7f369d7095025954f2069857801c0 127.0.0.1:7001
   slots:5461-10922 (5462 slots) master
M: 085d2851ef195428786f7df14a2c00fedb6ccec9 127.0.0.1:7100
   slots:10923-16383 (5461 slots) master
M: 97cf943c9fac35520fdd9426e344f7b7cc390fb8 127.0.0.1:7101
   slots: (0 slots) master
   replicates b70ce6df43039cd8ef2004a031851668dfe51982
M: e2fae64bbac1fc28d66c4cb21c5be95be4ba8953 127.0.0.1:7200
   slots: (0 slots) master
   replicates 3300b8f899d7f369d7095025954f2069857801c0
M: 5207520b05fd05240a56d132bf90fa4e9dde97cb 127.0.0.1:7300
   slots: (0 slots) master
   replicates 085d2851ef195428786f7df14a2c00fedb6ccec9
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
4、集群完整性檢查

集群完整性是指所有的槽都分配到了存活的主節(jié)點(diǎn)上,只要16384個(gè)槽中有一個(gè)沒有分配給節(jié)點(diǎn)則表示集群不完整;

可以使用redis-trib.rb check命令檢測之前創(chuàng)建的兩個(gè)集群是否成功,check命令只需要給出集群中任意一個(gè)節(jié)點(diǎn)地址就可以完成整個(gè)集群的檢查工作;

-- 命令如下: --
redis-trib.rb check 127.0.0.1:7000
redis-trib.rb check 127.0.0.1:7100

-- 輸出如下信息,提示集群所有的槽都已分配到節(jié)點(diǎn) --
[root@test cluster]# redis-trib.rb check 127.0.0.1:7000
>>> Performing Cluster Check (using node 127.0.0.1:7000)
M: b70ce6df43039cd8ef2004a031851668dfe51982 127.0.0.1:7000
   slots:0-5460 (5461 slots) master
   1 additional replica(s)
S: e2fae64bbac1fc28d66c4cb21c5be95be4ba8953 127.0.0.1:7200
   slots: (0 slots) slave
   replicates 3300b8f899d7f369d7095025954f2069857801c0
S: 97cf943c9fac35520fdd9426e344f7b7cc390fb8 127.0.0.1:7101
   slots: (0 slots) slave
   replicates b70ce6df43039cd8ef2004a031851668dfe51982
M: 085d2851ef195428786f7df14a2c00fedb6ccec9 127.0.0.1:7100
   slots:10923-16383 (5461 slots) master
   1 additional replica(s)
S: 5207520b05fd05240a56d132bf90fa4e9dde97cb 127.0.0.1:7300
   slots: (0 slots) slave
   replicates 085d2851ef195428786f7df14a2c00fedb6ccec9
M: 3300b8f899d7f369d7095025954f2069857801c0 127.0.0.1:7001
   slots:5461-10922 (5462 slots) master
   1 additional replica(s)
[OK] All nodes agree about slots configuration.
>>> Check for open slots...
>>> Check slots coverage...
[OK] All 16384 slots covered.
5、總結(jié)
1.    建立集群主要步驟如下:
              ①  準(zhǔn)備節(jié)點(diǎn)
              ②  節(jié)點(diǎn)握手【meet命令,是一個(gè)異步命令】
              ③  分配槽    【cluster addslots {number_start..number_end}】
2.    redis cluster 需要至少6個(gè)節(jié)點(diǎn),3個(gè)主節(jié)點(diǎn) +3個(gè)從節(jié)點(diǎn)
3.    主從節(jié)點(diǎn)必須為復(fù)制關(guān)系【cluster replicate 主節(jié)點(diǎn)ID 命令,建立復(fù)制關(guān)系】
4.    節(jié)點(diǎn)握手協(xié)議采用Gossip協(xié)議進(jìn)行通信,通過meet命令建立握手關(guān)系,通過ping/pong命令保持正常通信
5.    加入到集群中的節(jié)點(diǎn),在沒有分配槽時(shí),無法進(jìn)行任何讀寫操作;

相關(guān)鏈接:

手動(dòng)構(gòu)建redis集群

redis集群【報(bào)錯(cuò)總結(jié)】

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

名稱欄目:用redis-trib.rb搭建redis集群-創(chuàng)新互聯(lián)
網(wǎng)頁網(wǎng)址:http://muchs.cn/article8/dejoip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、微信公眾號ChatGPT、網(wǎng)站制作電子商務(wù)、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化