主頁 > 知識(shí)庫 > docker redis5.0 cluster集群搭建的實(shí)現(xiàn)

docker redis5.0 cluster集群搭建的實(shí)現(xiàn)

熱門標(biāo)簽:外呼線路隨意切換嗎 滴滴急救中心地圖標(biāo)注 淘寶辦理400電話是多少 福州語音電銷機(jī)器人招商 申請(qǐng)400電話收費(fèi)標(biāo) 菏澤自動(dòng)電銷機(jī)器人公司 北海智能電銷機(jī)器人公司 艾澤拉斯地圖標(biāo)注 網(wǎng)絡(luò)電話外呼系統(tǒng)開發(fā)

系統(tǒng)環(huán)境:ubuntu16.04LTS

本文是使用 6 個(gè) docker 容器搭建單機(jī)集群測(cè)試,實(shí)際環(huán)境如果是多臺(tái),可對(duì)應(yīng)修改容器數(shù)量、端口號(hào)和集群 ip 地址,每臺(tái)機(jī)器都按下面步驟同樣操作即可。

拉取redis官方鏡像

docker pull redis:5.0

創(chuàng)建配置文件和數(shù)據(jù)目錄

創(chuàng)建目錄

mkdir ~/redis_cluster
cd ~/redis_cluster

新建一個(gè)模板文件sudo vim redis_cluster.tmpl,填入如下內(nèi)容:

# redis端口
port ${PORT}

# 關(guān)閉保護(hù)模式
protected-mode no

# 開啟集群
cluster-enabled yes

# 集群節(jié)點(diǎn)配置
cluster-config-file nodes.conf

# 超時(shí)
cluster-node-timeout 5000

# 集群節(jié)點(diǎn)IP host模式為宿主機(jī)IP
cluster-announce-ip 10.10.100.197

# 集群節(jié)點(diǎn)端口 7000 - 7005
cluster-announce-port ${PORT}
cluster-announce-bus-port 1${PORT}

# 開啟 appendonly 備份模式
appendonly yes

# 每秒鐘備份
appendfsync everysec

# 對(duì)aof文件進(jìn)行壓縮時(shí),是否執(zhí)行同步操作
no-appendfsync-on-rewrite no

# 當(dāng)目前aof文件大小超過上一次重寫時(shí)的aof文件大小的100%時(shí)會(huì)再次進(jìn)行重寫
auto-aof-rewrite-percentage 100

# 重寫前AOF文件的大小最小值 默認(rèn) 64mb
auto-aof-rewrite-min-size 5120mb

# 關(guān)閉快照備份
save ""

批量創(chuàng)建配置文件和數(shù)據(jù)目錄,終端運(yùn)行以下命令:

for port in `seq 7000 7005`; do \

 mkdir -p ./${port}/conf \

 && PORT=${port} envsubst < ./redis_cluster.tmpl > ./${port}/conf/redis.conf \

 && mkdir -p ./${port}/data; \

done

批量啟動(dòng) redis 容器

容器的 ip 地址采用 host 模式:

for port in `seq 7000 7005`; do \

 docker run -d -it --memory=1G \

 -v ~/redis_cluster/${port}/conf/redis.conf:/usr/local/etc/redis/redis.conf \

 -v ~/redis_cluster/${port}/data:/data \

 --restart always --name redis-${port} --net host \

 --sysctl net.core.somaxconn=1024 redis:5.0 redis-server /usr/local/etc/redis/redis.conf; \

done

這里的--memeory=1G是限制單個(gè) docker 容器占用內(nèi)存大小為 1G,超過會(huì)被進(jìn)程殺死。運(yùn)行時(shí)可能會(huì)出現(xiàn)...Memory limited without swap...這個(gè)警告,可以忽略。如不需要限制內(nèi)存,可以去掉--memeory參數(shù)。

創(chuàng)建集群

隨便進(jìn)入其中一個(gè)容器:

docker exec -it redis-7000 bash

進(jìn)入后執(zhí)行如下命令創(chuàng)建集群:

redis-cli --cluster create 10.10.100.197:7000 10.10.100.197:7001 10.10.100.197:7002 10.10.100.197:7003 10.10.100.197:7004 10.10.100.197:7005 --cluster-replicas 1

安裝redis-cli命令(如已有可跳過此步):

sudo apt install redis-tools

輸入yes后,集群創(chuàng)建完畢,exit退出 docker,接著登錄其中一個(gè)節(jié)點(diǎn),驗(yàn)證集群可用性:

redis-cli -c -p 7000

輸入cluster nodes查看集群狀態(tài)

127.0.0.1:7000> cluster nodes
06851aa134d50096d82a434eced9194233b5204e 10.10.100.197:7003@17003 slave 8b33f273386c9504ef8bd10b005e24825b3b9596 0 1567671901000 4 connected
a42297b65f7101fc9e4941ef8a0e65080d1b6338 10.10.100.197:7005@17005 slave 0aa20378d14e3ef0859815196cbafa67e1001d0e 0 1567671901581 6 connected
e7b6a35b1e92f94c225c507ea19f7f0318f0d1c3 10.10.100.197:7002@17002 master - 0 1567671902582 3 connected 10923-16383
0aa20378d14e3ef0859815196cbafa67e1001d0e 10.10.100.197:7000@17000 myself,master - 0 1567671901000 1 connected 0-5460
8b33f273386c9504ef8bd10b005e24825b3b9596 10.10.100.197:7001@17001 master - 0 1567671902383 2 connected 5461-10922
fe355eed99100197f43d1216d1de82643dd496a5 10.10.100.197:7004@17004 slave e7b6a35b1e92f94c225c507ea19f7f0318f0d1c3 0 1567671901380 5 connected

設(shè)置集群密碼

設(shè)置密碼為什么不在上面的步驟,利用模板文件批量創(chuàng)建配置文件的時(shí)候就寫進(jìn)去?

無論是在 redis5.x 版本,還是以前的 redis 版本利用 ruby 創(chuàng)建集群的方式,在redis-cli --cluster create創(chuàng)建集群的環(huán)節(jié)沒有密碼參數(shù)配置,所以我們需要?jiǎng)?chuàng)建完集群再設(shè)置密碼。

我們用config set方式分別為每一個(gè)節(jié)點(diǎn)設(shè)置相同的密碼(不需要重啟 redis,且重啟后依然有效),在此之前先給所有 redis 配置文件加w權(quán)限,不然密碼無法保存到文件。

注意當(dāng)前路徑依然是在~/redis_cluster/:

for port in `seq 7000 7005`; do \

 chmod a+w ./${port}/conf/redis.conf; \

done

下面用一臺(tái)做示例:

登錄一個(gè)節(jié)點(diǎn):

redis-cli -c -p 7000

設(shè)置密碼:

127.0.0.1:7000> config set masterauth 123456
OK
127.0.0.1:7000> config set requirepass 123456
OK
127.0.0.1:7000> auth 123456
OK
127.0.0.1:7000> config rewrite
OK

后面幾臺(tái)執(zhí)行同樣的操作即可。

集群寫入數(shù)據(jù)簡(jiǎn)單測(cè)試

隨便登錄一個(gè)集群節(jié)點(diǎn):

redis-cli -c -p 7003 -a 123456

寫入數(shù)據(jù):

127.0.0.1:7003> set va 1
-> Redirected to slot [7800] located at 10.10.100.197:7001
OK
10.10.100.197:7001> get va
"1"
10.10.100.197:7001> del va
(integer) 1

可以看到,集群中任意節(jié)點(diǎn)寫入數(shù)據(jù),在其他任意節(jié)點(diǎn)都能讀到。

至此,redis 集群搭建完成。

其他注意事項(xiàng)

  • 外網(wǎng)訪問 redis,可能需要防火墻開放相應(yīng)端口;
  • 如果需要?jiǎng)h除容器,可批量操作:
for port in `seq 7000 7005`; do \

 docker stop redis-${port};
 docker rm redis-${port};
done

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:三沙 滄州 延安 亳州 賀州 丹東 混顯 資陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《docker redis5.0 cluster集群搭建的實(shí)現(xiàn)》,本文關(guān)鍵詞  docker,redis5.0,cluster,集群,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《docker redis5.0 cluster集群搭建的實(shí)現(xiàn)》相關(guān)的同類信息!
  • 本頁收集關(guān)于docker redis5.0 cluster集群搭建的實(shí)現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章