教你一分鐘搞定docker+redis哨兵模式
“工欲善其事,必先利其器”,要想在一分鐘內(nèi)搞定docker+redis哨兵模式(一主二從三哨兵),按下述方法,則快捷,迅速,省時(shí)省力:
注:本文主要講解一主二從三哨兵,特將其部署到一臺(tái)機(jī)器上,并通過(guò)端口區(qū)分(生產(chǎn)環(huán)境要部署到三臺(tái)及以上機(jī)器上)。
一 前期準(zhǔn)備工作
要求具備下面環(huán)境或相應(yīng)適配版本環(huán)境:
※Centos 7.9版
※GNU Make 3.82版
※gcc 4.8.5版
※Docker 20.10.18版
※sentinel.conf文件
下載方法:
wget https://download.redis.io/redis-stable/sentinel.conf
※docker-compose 1.29.2版
技術(shù)更新較快,用docker-compose比較快捷。
安裝方法:
命令1:
curl -L https://get.daocloud.io/docker/compose/releases/download/1.29.2/docker-compose-uname -s-uname -m > /usr/local/bin/docker-compose
命令2:
chmod +x /usr/local/bin/docker-compose
二、部署(一分鐘)
1、獲取 redis 鏡像
安裝命令:
docker pull redis:5.0.14
2 建目錄
命令1:
mkdir /usr/local/etc/redis
命令2:
mkdir /usr/local/etc/redis/sentinel
3 在 /usr/local/etc/redis 目錄下,新建 docker-compose.yml文件
version: '3' services: master: image: redis container_name: redis-master command: redis-server ports: - 6379:6379 slave1: image: redis container_name: redis-slave1 ports: - 6380:6380 command: redis-server --slaveof redis-master 6379 slave2: image: redis container_name: redis-slave2 ports: - 6381:6381 command: redis-server --slaveof redis-master 6379
4 啟動(dòng) redis 集群
在./redis目錄運(yùn)行命令:
docker-compose up -d
5查看 redis-master 節(jié)點(diǎn)的 docker-ip 和 network name,
見(jiàn)下圖,并記住,待配置sentinel的docker-compose文件時(shí)用。
命令:
docker inspect redis-master
6.在 /usr/local/etc/redis/sentinel 目錄下,新建 docker-compose.yml文件
version: '3' services: sentinel1: image: redis container_name: redis-sentinel1 ports: - 26379:26379 command: redis-sentinel /usr/local/etc/redis/sentinel/sentinel1.conf volumes: - ./sentinel1.conf:/usr/local/etc/redis/sentinel/sentinel1.conf sentinel2: image: redis container_name: redis-sentinel2 ports: - 26380:26380 command: redis-sentinel /usr/local/etc/redis/sentinel/sentinel2.conf volumes: - ./sentinel2.conf:/usr/local/etc/redis/sentinel/sentinel2.conf sentinel3: image: redis container_name: redis-sentinel3 ports: - 26381:26381 command: redis-sentinel /usr/local/etc/redis/sentinel/sentinel3.conf volumes: - ./sentinel3.conf:/usr/local/etc/redis/sentinel/sentinel3.conf networks: default: external: name: redis_default
7 將sentinel.conf文件拷貝至/usr/local/etc/redis/sentinel
并復(fù)制三份,名稱分別為sentinel1.conf 、 sentinel2.conf 、 sentinel3.conf,分別修改三個(gè)文件:
修改的內(nèi)容如下:
修改 sentinel1.conf
文件修改內(nèi)容如下:
protected-mode no
daemonize yes
port 26379 #sentinel 端口
sentinel monitor mymaster 172.18.0.3 6379 2 #注:172.18.0.3為redis-master的dockerIP
然后修改sentinel2.conf信息如下:
protected-mode no
daemonize yes
port 26380 # sentinel 端口,因?yàn)槲覀冊(cè)谝慌_(tái)虛擬機(jī)上,所以端口要不一樣
sentinel monitor mymaster 172.18.0.3 6379 2 #注:172.18.0.3為redis-master的dockerIP
然后修改sentinel3.conf信息如下:
protected-mode no
daemonize yes
port 26381 # sentinel 端口,因?yàn)槲覀冊(cè)谝慌_(tái)虛擬機(jī)上,所以端口要不一樣
dir “/var/llib/redis”
sentinel monitor mymaster 172.18.0.3 6379 2 #注:172.18.0.3為redis-master的dockerIP
8 在./sentinel目錄啟動(dòng) sentinel 集群
命令:
docker-compose up -d
經(jīng)此8步,完成docker下的redis一主二從三哨兵模式。
三、驗(yàn)證方法
1 驗(yàn)證是否安裝好
*檢測(cè)容器命令:
docker ps
看是否有以下6個(gè)容器。
*登錄主機(jī)命令:
docker exec -it redis-master /bin/bash redis-cli info Replication
出現(xiàn)下面畫(huà)面,證明redis主機(jī)安裝成功。
*登錄從機(jī)redis-slave1及redis-slave2命令:
*登錄哨兵命令:
docker exec -it redis-sentinel1 /bin/bash redis-cli -p 26379 info sentinel
如下圖,則哨兵安裝成功。
*查看哨兵sentinel日志:
命令:
docker logs -f redis-sentinel1
如下圖所示,也證明哨兵安裝成功
2 1驗(yàn)證主從機(jī)切換
*停掉主機(jī)redis-master服務(wù),可以直接將容器關(guān)掉。
命令:
docker stop redis-master
*登錄從機(jī)1(slave1)
命令:
docker exec -it redis-slave1 /bin/bash redis-cli info Replication
發(fā)現(xiàn)從機(jī)變?yōu)橹鳈C(jī),如下圖:
到此這篇關(guān)于教你一分鐘搞定docker+redis哨兵模式的文章就介紹到這了,更多相關(guān)docker+redis哨兵模式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 基于Docker搭建Redis一主兩從三哨兵的實(shí)現(xiàn)
- Docker配置redis哨兵模式的方法(多服務(wù)器上)
- 5分鐘教你實(shí)現(xiàn)用docker搭建Redis集群模式和哨兵模式
- 基于Docker實(shí)現(xiàn)Redis主從+哨兵搭建的示例實(shí)踐
- docker搭建redis主從哨兵集群的實(shí)現(xiàn)步驟
- docker搭建redis哨兵集群并且整合springboot的實(shí)現(xiàn)
- 使用Docker配置redis sentinel哨兵的方法步驟
- Docker下Redis集群(主從+哨兵)安裝配置的實(shí)現(xiàn)步驟
- 基于docker的redis主從及哨兵配置方式
- docker安裝Redis高可用實(shí)現(xiàn)一主二從三哨兵
相關(guān)文章
linux上安裝Docker(非常簡(jiǎn)單的安裝方法)
今天小編就為大家分享一篇關(guān)于linux上安裝Docker(非常簡(jiǎn)單的安裝方法),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-04-04Docker運(yùn)行springboot項(xiàng)目的實(shí)現(xiàn)
這篇文章主要介紹了Docker運(yùn)行springboot項(xiàng)目的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12使用Docker Swarm搭建分布式爬蟲(chóng)集群的方法示例
這篇文章主要介紹了使用Docker Swarm搭建分布式爬蟲(chóng)集群的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10Docker容器與宿主機(jī)相互訪問(wèn)更方便的方法
Docker是當(dāng)今使用范圍最廣的開(kāi)源容器技術(shù)之一,具有高效易用的優(yōu)點(diǎn),然而如果使用Docker時(shí)采取不當(dāng)安全策略,則可能導(dǎo)致系統(tǒng)面臨安全威脅,這篇文章主要給大家介紹了關(guān)于Docker容器與宿主機(jī)相互訪問(wèn)更方便的方法,需要的朋友可以參考下2023-05-05解決docker pull被復(fù)位出現(xiàn)的問(wèn)題
這篇文章主要介紹了解決docker pull被復(fù)位出現(xiàn)的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09docker compose自定義網(wǎng)絡(luò)實(shí)現(xiàn)固定容器ip地址
這篇文章主要介紹了docker compose自定義網(wǎng)絡(luò)實(shí)現(xiàn)固定容器ip地址,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01Docker數(shù)據(jù)存儲(chǔ)總結(jié)
今天小編就為大家分享一篇關(guān)于Docker數(shù)據(jù)存儲(chǔ)總結(jié),小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02