欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何搭建dockerredis5.0cluster集群

這篇文章給大家分享的是有關如何搭建docker redis5.0 cluster集群的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

同安網(wǎng)站建設公司創(chuàng)新互聯(lián)建站,同安網(wǎng)站設計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為同安成百上千提供企業(yè)網(wǎng)站建設服務。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設要多少錢,請找那個售后服務好的同安做網(wǎng)站的公司定做!

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

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

拉取redis官方鏡像

docker pull redis:5.0

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

創(chuàng)建目錄

mkdir ~/redis_cluster
cd ~/redis_cluster

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

# redis端口
port ${PORT}

# 關閉保護模式
protected-mode no

# 開啟集群
cluster-enabled yes

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

# 超時
cluster-node-timeout 5000

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

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

# 開啟 appendonly 備份模式
appendonly yes

# 每秒鐘備份
appendfsync everysec

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

# 當目前aof文件大小超過上一次重寫時的aof文件大小的100%時會再次進行重寫
auto-aof-rewrite-percentage 100

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

# 關閉快照備份
save ""

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

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

批量啟動 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是限制單個 docker 容器占用內(nèi)存大小為 1G,超過會被進程殺死。運行時可能會出現(xiàn)...Memory limited without swap...這個警告,可以忽略。如不需要限制內(nèi)存,可以去掉--memeory參數(shù)。

創(chuàng)建集群

隨便進入其中一個容器:

docker exec -it redis-7000 bash

進入后執(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,接著登錄其中一個節(jié)點,驗證集群可用性:

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

設置集群密碼

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

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

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

注意當前路徑依然是在~/redis_cluster/:

for port in `seq 7000 7005`; do \
 chmod a+w ./${port}/conf/redis.conf; \
done

下面用一臺做示例:

登錄一個節(jié)點:

redis-cli -c -p 7000

設置密碼:

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

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

集群寫入數(shù)據(jù)簡單測試

隨便登錄一個集群節(jié)點:

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é)點寫入數(shù)據(jù),在其他任意節(jié)點都能讀到。

至此,redis 集群搭建完成。

其他注意事項

  • 外網(wǎng)訪問 redis,可能需要防火墻開放相應端口;

  • 如果需要刪除容器,可批量操作:

for port in `seq 7000 7005`; do \
 docker stop redis-${port};
 docker rm redis-${port};
done

感謝各位的閱讀!關于“如何搭建docker redis5.0 cluster集群”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

網(wǎng)站欄目:如何搭建dockerredis5.0cluster集群
網(wǎng)站路徑:http://aaarwkj.com/article34/pesgpe.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、外貿(mào)建站移動網(wǎng)站建設、域名注冊、定制網(wǎng)站用戶體驗

廣告

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

成都定制網(wǎng)站建設
国产91在线视频播放| 亚洲综合日韩丝袜人妻| 欧美欧成人一区二区三区a∨| 久久国产精品亚洲av四虎| 国产三级黄色大片在线免费看| 色婷婷区二区三区四区| 久久人热视频这里只有精品| 97免费在线视频观看| 亚洲成在人天堂一区二区| 亚洲日本精品一区二区三区| 日进去了啊内射视频| 在线国产精品中文字幕| 91亚洲蜜桃内射后入在线观看 | 精品久久久久久亚洲电影| 91亚色在线免费观看| 91九色在线免费观看| 久久96国产精品久久秘臀| 欧美日韩一区中文字幕| 日韩人妻精品久久免费| 亚洲欧美日韩国产99| 天天干夜夜操天天射| 欧美一区二区日本国产激情| 人人爽人人妻人人澡| 亚洲精品一品区二品区三| 午夜福利视频欧美成人| 国产亚洲精品久久久久久| 亚洲精品熟女国产国产老熟女| 国产三级黄色片免费看| 欧美亚洲国产精品综合在线| 亚洲激情视频在线视频| 欧美国产日本日韩在线黄| 国产伊人久久综合网| 日韩三级精品一区二区| 中文字幕在线感觉av| 精品国产成人一区二区| 色婷婷综合激情一区二区| 粉嫩美女精品一区二区| 一区二区三区熟妇人妻视频| 久久国产精品午夜亚洲欧美| 黄色录像免费一内片一级| 国产日产精品久久婷婷色|