RedisCluster--安裝配置-創(chuàng)新互聯(lián)

背景

10年積累的成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站制作后付款的網(wǎng)站建設(shè)流程,更有平陽免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

本篇主要講Redis Cluster的安裝,讓我們先用起來,感受一下到底是怎么回事,后面再繼續(xù)學(xué)習(xí)有關(guān)如何Cluster如何failover,添加節(jié)點(diǎn),刪除節(jié)點(diǎn),遷移slots等功能。

Redis Cluster特點(diǎn)

(1)Redis Cluster 共有16384(0-16383)個(gè)hash slots,數(shù)據(jù)寫入時(shí),根據(jù)CRC16('key')%16384 hash slots分配到不同的節(jié)點(diǎn)上;

(2)當(dāng)整個(gè)集群部分節(jié)點(diǎn)crash不影響繼續(xù)使用,如有A,B,C三個(gè)master和A1,B1,C1三個(gè)slave組成的cluster,如果B宕機(jī),則B1會(huì)自動(dòng)提成為master,當(dāng)B恢復(fù)之后,也會(huì)自動(dòng)成為B1的slave,保證集群的高可用性;

(3)當(dāng)集群負(fù)載比較高,不足以支撐現(xiàn)在的業(yè)務(wù),可以添加空節(jié)點(diǎn),然后rebalance slot或者reshard slot;

安裝Redis Cluster

(1)環(huán)境準(zhǔn)備

Redis版本都是3.2.9,有6個(gè)redis實(shí)例分別在6臺(tái)不同的主機(jī)上運(yùn)行,其中3個(gè)作為Master,另外3個(gè)分別作為它們的Slave存在,端口統(tǒng)一使用默認(rèn)的端口6379;

Redis Cluster--安裝配置

Master1: sht-sgmhadoopcm-01(172.16.101.54)

Slave1: sht-sgmhadoopdn-01(172.16.101.58)

Master2: sht-sgmhadoopnn-01(172.16.101.55)

Slave2: sht-sgmhadoopdn-02(172.16.101.59)

Master3: sht-sgmhadoopnn-02(172.16.101.56)

Slave3: sht-sgmhadoopdn-03(172.16.101.60)

修改配置文件,每個(gè)節(jié)點(diǎn)都需要執(zhí)行,修改其他節(jié)點(diǎn)對(duì)應(yīng)的IP地址

[root@sht-sgmhadoopcm-01 redis]# vim redis.conf port 6379 bind 172.16.101.54   appendonly yes cluster-enabled yes cluster-config-file nodes-6379.conf cluster-node-timeout 15000

(2)在需要ruby的節(jié)點(diǎn)上安裝ruby

[root@sht-sgmhadoopcm-01 redis]# yum install ruby -y

下面這一步可能報(bào)錯(cuò),因?yàn)镃entOS7.3默認(rèn)安裝的ruby2.0.0,版本太低

[root@sht-sgmhadoopcm-01 redis]# gem install redis Fetching: redis-4.0.1.gem (100%) Successfully installed redis-4.0.1 Parsing documentation for redis-4.0.1 Installing ri documentation for redis-4.0.1 Done installing documentation for redis after 2 seconds 1 gem installed

(3)啟動(dòng)所有節(jié)點(diǎn)

[root@sht-sgmhadoopcm-01 redis]# src/redis-server redis.conf [root@sht-sgmhadoopnn-02 redis]# src/redis-server redis.conf [root@sht-sgmhadoopnn-01 redis]# src/redis-server redis.conf [root@sht-sgmhadoopdn-01 redis]# src/redis-server redis.conf [root@sht-sgmhadoopdn-02 redis]# src/redis-server redis.conf [root@sht-sgmhadoopdn-03 redis]# src/redis-server redis.conf [root@sht-sgmhadoopnn-02 redis]# ps -ef|grep redis root      1716     1  0 12:40 ?        00:00:00 src/redis-server 172.16.101.56:6379 [cluster] root      1720  1504  0 12:41 pts/2    00:00:00 grep --color=auto redis

(4)使用redis-trib.rb腳本創(chuàng)建cluster

Create的過程中已經(jīng)給三個(gè)master分配好了hash slots,并且制定好Slave;

選項(xiàng)--replicas 1 表示為每個(gè)創(chuàng)建的主服務(wù)器節(jié)點(diǎn)創(chuàng)建一個(gè)從服務(wù)器節(jié)點(diǎn);

[root@sht-sgmhadoopcm-01 redis]# ruby src/redis-trib.rb create --replicas 1 172.16.101.54:6379 172.16.101.55:6379 172.16.101.56:6379 172.16.101.58:6379 172.16.101.59:6379 172.16.101.60:6379 >>> Creating cluster >>> Performing hash slots allocation on 6 nodes... Using 3 masters: 172.16.101.54:6379 172.16.101.55:6379 172.16.101.56:6379 Adding replica 172.16.101.58:6379 to 172.16.101.54:6379 Adding replica 172.16.101.59:6379 to 172.16.101.55:6379 Adding replica 172.16.101.60:6379 to 172.16.101.56:6379 M: 610aa83831404be545b25cc7f7322e987da1dd33 172.16.101.54:6379    slots:0-5460 (5461 slots) master M: 4c7348ac575a1a3bd4357e937a8f94f1654193cf 172.16.101.55:6379    slots:5461-10922 (5462 slots) master M: ece3a80f6989fa7f8316d73ee30ceea84340f24e 172.16.101.56:6379    slots:10923-16383 (5461 slots) master S: 28e8d5c8fd12533622d8110f8d262cb50120ca02 172.16.101.58:6379    replicates 610aa83831404be545b25cc7f7322e987da1dd33 S: b50ba506525ee547823b3d9a7e5a095933e3ff42 172.16.101.59:6379    replicates 4c7348ac575a1a3bd4357e937a8f94f1654193cf S: c79de1092011ed395ee772969274c0567c2b5dd1 172.16.101.60:6379    replicates ece3a80f6989fa7f8316d73ee30ceea84340f24e 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 172.16.101.54:6379) M: 610aa83831404be545b25cc7f7322e987da1dd33 172.16.101.54:6379    slots:0-5460 (5461 slots) master    1 additional replica(s) S: b50ba506525ee547823b3d9a7e5a095933e3ff42 172.16.101.59:6379    slots: (0 slots) slave    replicates 4c7348ac575a1a3bd4357e937a8f94f1654193cf S: 28e8d5c8fd12533622d8110f8d262cb50120ca02 172.16.101.58:6379    slots: (0 slots) slave    replicates 610aa83831404be545b25cc7f7322e987da1dd33 M: 4c7348ac575a1a3bd4357e937a8f94f1654193cf 172.16.101.55:6379    slots:5461-10922 (5462 slots) master    1 additional replica(s) M: ece3a80f6989fa7f8316d73ee30ceea84340f24e 172.16.101.56:6379    slots:10923-16383 (5461 slots) master    1 additional replica(s) S: c79de1092011ed395ee772969274c0567c2b5dd1 172.16.101.60:6379    slots: (0 slots) slave    replicates ece3a80f6989fa7f8316d73ee30ceea84340f24e [OK] All nodes agree about slots configuration. >>> Check for open slots... >>> Check slots coverage... [OK] All 16384 slots covered.

(5)查看Cluster基本信息

[root@sht-sgmhadoopcm-01 redis]# src/redis-cli -c -h 172.16.101.54 -p 6379 172.16.101.54:6379> info replication # Replication role:master connected_slaves:1 slave0:ip=172.16.101.58,port=6379,state=online,offset=2591,lag=0 master_repl_offset:2591 repl_backlog_active:1 repl_backlog_size:1048576 repl_backlog_first_byte_offset:2 repl_backlog_histlen:2590 172.16.101.54:6379> cluster info cluster_state:ok cluster_slots_assigned:16384 cluster_slots_ok:16384 cluster_slots_pfail:0 cluster_slots_fail:0 cluster_known_nodes:6 cluster_size:3 cluster_current_epoch:6 cluster_my_epoch:1 cluster_stats_messages_sent:4462 cluster_stats_messages_received:4462 172.16.101.54:6379> cluster nodes b50ba506525ee547823b3d9a7e5a095933e3ff42 172.16.101.59:6379 slave 4c7348ac575a1a3bd4357e937a8f94f1654193cf 0 1532497136876 5 connected 610aa83831404be545b25cc7f7322e987da1dd33 172.16.101.54:6379 myself,master - 0 0 1 connected 0-5460 28e8d5c8fd12533622d8110f8d262cb50120ca02 172.16.101.58:6379 slave 610aa83831404be545b25cc7f7322e987da1dd33 0 1532497135872 4 connected 4c7348ac575a1a3bd4357e937a8f94f1654193cf 172.16.101.55:6379 master - 0 1532497133867 2 connected 5461-10922 ece3a80f6989fa7f8316d73ee30ceea84340f24e 172.16.101.56:6379 master - 0 1532497134870 3 connected 10923-16383 c79de1092011ed395ee772969274c0567c2b5dd1 172.16.101.60:6379 slave ece3a80f6989fa7f8316d73ee30ceea84340f24e 0 1532497137878 6 connected [root@sht-sgmhadoopcm-01 redis]# cat nodes-6379.conf b50ba506525ee547823b3d9a7e5a095933e3ff42 172.16.101.59:6379 slave 4c7348ac575a1a3bd4357e937a8f94f1654193cf 0 1532493960094 5 connected 610aa83831404be545b25cc7f7322e987da1dd33 172.16.101.54:6379 myself,master - 0 0 1 connected 0-5460 28e8d5c8fd12533622d8110f8d262cb50120ca02 172.16.101.58:6379 slave 610aa83831404be545b25cc7f7322e987da1dd33 0 1532493955077 4 connected 4c7348ac575a1a3bd4357e937a8f94f1654193cf 172.16.101.55:6379 master - 0 1532493958087 2 connected 5461-10922 ece3a80f6989fa7f8316d73ee30ceea84340f24e 172.16.101.56:6379 master - 0 1532493956080 3 connected 10923-16383 c79de1092011ed395ee772969274c0567c2b5dd1 172.16.101.60:6379 slave ece3a80f6989fa7f8316d73ee30ceea84340f24e 0 1532493959091 6 connected vars currentEpoch 6 lastVoteEpoch 0

FAQ

Error1: ruby2.0.0版本太低

[root@sht-sgmhadoopcm-01 redis]# gem install redis Fetching: redis-4.0.1.gem (100%) ERROR:  Error installing redis:     redis requires Ruby version >= 2.2.2.

解決方法:

[root@sht-sgmhadoopcm-01 redis]# ruby --version ruby 2.0.0p648 (2015-12-16) [x86_64-linux] [root@sht-sgmhadoopcm-01 redis]# gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 7D2BAF1CF37B13E2069D6956105BD0E739499BDB [root@sht-sgmhadoopcm-01 redis]# curl -sSLhttps://get.rvm.io | bash -s stable [root@sht-sgmhadoopcm-01 redis]# find / -name rvm -print /usr/local/rvm /usr/local/rvm/src/rvm /usr/local/rvm/src/rvm/bin/rvm /usr/local/rvm/src/rvm/lib/rvm /usr/local/rvm/src/rvm/scripts/rvm /usr/local/rvm/bin/rvm /usr/local/rvm/lib/rvm /usr/local/rvm/scripts/rvm [root@sht-sgmhadoopcm-01 redis]# source /usr/local/rvm/scripts/rvm [root@sht-sgmhadoopcm-01 redis]# rvm list known [root@sht-sgmhadoopcm-01 redis]# rvm install 2.4.1 [root@sht-sgmhadoopcm-01 redis]# rvm use 2.4.1 Using /usr/local/rvm/gems/ruby-2.4.1 [root@sht-sgmhadoopcm-01 redis]# rvm use 2.4.1 --default Using /usr/local/rvm/gems/ruby-2.4.1 [root@sht-sgmhadoopcm-01 redis]# rvm remove 2.3.4 ruby-2.3.4 - #already gone Using /usr/local/rvm/gems/ruby-2.4.1 [root@sht-sgmhadoopcm-01 redis]# ruby --version ruby 2.4.1p111 (2017-03-22 revision 58053) [x86_64-linux]

Error2:添加節(jié)點(diǎn)數(shù)據(jù)不為空

[root@sht-sgmhadoopcm-01 redis]# src/redis-trib.rb add-node 172.16.101.66:6379 172.16.101.54:6379 ...... [ERR] Node 172.16.101.66:6379 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.

解決方法:

(1)刪除aof和rdb文件

(2)刪除nodes-6379.conf配置文件

(3)執(zhí)行flushdb and flushall

參考鏈接

https://redis.io/topics/cluster-tutorial

另外有需要云服務(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)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

分享名稱:RedisCluster--安裝配置-創(chuàng)新互聯(lián)
文章來源:http://bm7419.com/article28/dgccjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、網(wǎng)站建設(shè)標(biāo)簽優(yōu)化、網(wǎng)站營銷網(wǎng)站導(dǎo)航、營銷型網(wǎng)站建設(shè)

廣告

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

網(wǎng)站托管運(yùn)營