溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

搭建和部署Redis集群

發(fā)布時(shí)間:2020-05-29 15:33:17 來(lái)源:億速云 閱讀:302 作者:鴿子 欄目:云計(jì)算

一、Redis Cluster(Redis集群)簡(jiǎn)介:

(1)edis是一個(gè)開(kāi)源的key value存儲(chǔ)系統(tǒng),受到了廣大互聯(lián)網(wǎng)公司的青睞。redis3.0版本之前只支持單例模式,在3.0版本及以后才支持集群,這里我搭建用的是最新的版本 redis-5.0.7;

(2)redis集群采用P2P模式,是完全去中心化的,不存在中心節(jié)點(diǎn)或者代理節(jié)點(diǎn);

(3)redis集群是沒(méi)有統(tǒng)一的入口的,客戶端(client)連接集群的時(shí)候連接集群中的任意節(jié)點(diǎn)(node)即可,集群內(nèi)部的節(jié)點(diǎn)是相互通信的(PING-PONG機(jī)制),每個(gè)節(jié)點(diǎn)都是一個(gè)redis實(shí)例。

二、集群搭建需要的環(huán)境:

(1)Redis集群至少需要3個(gè)節(jié)點(diǎn),因?yàn)橥镀比蒎e(cuò)機(jī)制要求超過(guò)半數(shù)節(jié)點(diǎn)認(rèn)為某個(gè)節(jié)點(diǎn)掛了該節(jié)點(diǎn)才是掛了,所以2個(gè)節(jié)點(diǎn)無(wú)法構(gòu)成集群。

(2)要保證集群的高可用,需要每個(gè)節(jié)點(diǎn)都有從節(jié)點(diǎn),也就是備份節(jié)點(diǎn),所以Redis集群至少需要6臺(tái)服務(wù)器

(3)安裝ruby

三、部署集群:

為了節(jié)省資源,這邊準(zhǔn)備了兩臺(tái)虛擬機(jī),各自安裝三個(gè)網(wǎng)卡,這樣總共就是六個(gè)網(wǎng)卡,也就是同時(shí)運(yùn)行6個(gè) redis 實(shí)例。

角色      IP地址

redis1  192.168.220.131

redis2  192.168.220.164

redis3  192.168.220.165

redis4  192.168.220.135

redis5  192.168.220.166

redis6  192.168.220.167

第一步:先都安裝好 redis 服務(wù)

第二步:修改配置文件,所有節(jié)點(diǎn)配置一樣

vim /etc/redis/6379.conf

1、首先要注釋掉 bind 項(xiàng):
//redis 中 bind 選項(xiàng)默認(rèn)監(jiān)聽(tīng)所有網(wǎng)卡

2、做如下操作:

protected-mode no      //關(guān)閉保護(hù)模式
port 6379              //開(kāi)啟監(jiān)聽(tīng)端口
daemonize yes          //以獨(dú)立進(jìn)程啟動(dòng)
cluster-enabled yes    //開(kāi)啟群集功能
cluster-config-file nodes-6379.conf     //群集名稱文件位置
cluster-node-timeout 15000        //群集超時(shí)時(shí)間設(shè)置
appendonly yes                    //開(kāi)啟aof持久化               

(1)重啟服務(wù):

/etc/init.d/redis_6379 restart

(2)重啟過(guò)后,此時(shí)在 /var/lib/redis/6379 這個(gè)目錄下,就會(huì)多出兩個(gè)文件:

appendonly.aof :持久化文件
nodes-6379.conf :節(jié)點(diǎn)首次啟動(dòng)生成的配置文件

搭建和部署Redis集群

第三步:這步只需要在 master 主服務(wù)器中操作

1、導(dǎo)入 key 文件:
gpg --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3
2、安裝 rvm :
curl -sSL https://get.rvm.io | bash -s stable
1
3、執(zhí)行環(huán)境變量:
source /etc/profile.d/rvm.sh

rvm list known   //列出 Ruby 可安裝的版本
4、安裝 Ruby2.4.1 版本
rvm install 2.4.1
5、使用 Ruby2.4.1 版本
rvm use 2.4.1

ruby -v    //查看當(dāng)前 Ruby2.4.1 版本

搭建和部署Redis集群

6、再次安裝 Redis
gem install redis

搭建和部署Redis集群

7、重新啟動(dòng) redis
/etc/init.d/redis_6379 restart

第四步:創(chuàng)建群集

六個(gè)實(shí)例分為三組,每組一主一從,–replicas 1 表示每組一個(gè)從,下面交互的時(shí)候,需要輸入 yes 才可以創(chuàng)建。
使用源碼解壓目錄中的 redis-trib.rb 工具創(chuàng)建群集。
redis-cli --cluster create 192.168.220.131:6379 192.168.220.164:6379 192.168.220.165:6379 192.168.220.135:6379 192.168.220.166:6379 192.168.220.167:6379 --cluster-replicas 1

搭建和部署Redis集群

第五步:驗(yàn)證:

(1)隨意登錄一臺(tái) redis,創(chuàng)建一對(duì)鍵值:
redis-cli -h 192.168.220.164 -p 6379        //連接164這臺(tái)主機(jī)

搭建和部署Redis集群

(2)此時(shí),我們連接登錄到另外一臺(tái)主機(jī)上,查看鍵名:
 redis-cli -h 192.168.220.131 -p 6379      //連接到131這臺(tái)主機(jī)上

搭建和部署Redis集群

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI