docker-compose一鍵部署redis一主二從三哨兵模式(含密碼,數據持久化)

来源:https://www.cnblogs.com/hckblogs/archive/2019/07/14/11186311.html
-Advertisement-
Play Games

本篇基於centos7伺服器進行部署開發 代碼地址:https://github.com/chukaihong/docker-compose.喜歡的點個start 一.拉取redis鏡像,使用如下命令 1.查看鏡像是否拉取成功,使用如下命令 顯示如下則證明拉取成功 二.編寫docker-compos ...


本篇基於centos7伺服器進行部署開發

代碼地址:https://github.com/chukaihong/docker-compose.喜歡的點個start

一.拉取redis鏡像,使用如下命令

docker pull redis

1.查看鏡像是否拉取成功,使用如下命令

docker images

顯示如下則證明拉取成功

二.編寫docker-compose.yml文件實現redis一主二從

version: '3.7'
services:
  master:
    image: redis
    container_name: redis-master
    restart: always
    command: redis-server --port 6379 --requirepass test@dbuser2018  --appendonly yes
    ports:
      - 6379:6379
    volumes:
      - ./data:/data

  slave1:
    image: redis
    container_name: redis-slave-1
    restart: always
    command: redis-server --slaveof 192.168.8.188 6379 --port 6380  --requirepass test@dbuser2018 --masterauth test@dbuser2018  --appendonly yes
    ports:
      - 6380:6380
    volumes:
      - ./data:/data


  slave2:
    image: redis
    container_name: redis-slave-2
    restart: always
    command: redis-server --slaveof 192.168.8.188 6379 --port 6381  --requirepass test@dbuser2018 --masterauth test@dbuser2018  --appendonly yes
    ports:
      - 6381:6381
    volumes:
      - ./data:/data

1.名詞解釋

 名詞  描述
 version  docker文件的版本
 image  指定容器鏡像就是之前拉取的redis鏡像
 container_name  給這個鏡像起一個別名
 restart  always:表名開機自啟動
 command  相當於執行一些命令   (--requirepass 指定redis密碼  --appendonly yes 這個命令是用於開啟redis數據持久化)
 ports  埠映射,將容器的埠映射到對應宿主機的埠
 volumes  數據捲的映射.因為一旦容器停止了那麼裡面的數據也沒有.所以我們需要把這個數據文件放在外面,然後映射到容器中

 

 

 

 

 

 

 

 

 

2. 啟動redis,使用如下命令    -d 掛在後臺

docker-compose up -d

 查看redis是否啟動成功,使用如下命令,看到紅框中的三個並且狀態是 UP  則表明啟動redis成功

如果使用失敗了,可以使用如下命令查看日誌,觀察是什麼原因造成的

docker logs -f 容器Id

停止redis,使用如下命令

docker-compose down

或者

docker stop 容器Id
docker rm 容器Id

停止並移除所有容器可以使用如下命令

docker stop $(docker ps -a -q)
docker rm $(docker ps -a -q)

查看redis是否實現了一主二從的功能

進入主redis容器中,使用如下命令

docker exec -it 容器Id bash

 顯示如下則表明進入到容器中

對主redis進行操作,證明該主redis具備正常的寫入功能

證明完畢,退出容器. ctrl+c退出redis,輸入如下命令退出容器

exit

 同樣方式進入到redis從伺服器,查看是否能獲取到name6且不具備寫功能

至此,redis一主二從完畢,如果想知道數據是否被持久化可以執行如下命令。查看是否有name6這個key,有則表明數據持久化成功。

docker-compose down  
docker-compose up -d

三.部署redis-sentinel

1.編寫docker-compose.yml 

version: '3.7'
services:
  sentinel1:
    image: redis
    container_name: redis-sentinel-1
    command: redis-sentinel /usr/local/etc/redis/sentinel.conf
    restart: always
    ports:
      - 26379:26379
    volumes:
      - ./sentinel1.conf:/usr/local/etc/redis/sentinel.conf

  sentinel2:
    image: redis
    container_name: redis-sentinel-2
    command: redis-sentinel /usr/local/etc/redis/sentinel.conf
    restart: always
    ports:
      - 26380:26379
    volumes:
      - ./sentinel2.conf:/usr/local/etc/redis/sentinel.conf

  sentinel3:
    image: redis
    container_name: redis-sentinel-3
    command: redis-sentinel /usr/local/etc/redis/sentinel.conf
    restart: always
    ports:
      - 26381:26379
    volumes:
      - ./sentinel3.conf:/usr/local/etc/redis/sentinel.conf

2.編寫sentinel.conf

port 26379
dir /tmp
# 自定義集群名,其中 192.168.8.188 為 redis-master 的 ip,6379 為 redis-master 的埠,2 為最小投票數(因為有 3 台 Sentinel 所以可以設置成 2)
sentinel monitor mymaster 192.168.8.188 6379 2
sentinel down-after-milliseconds mymaster 30000
sentinel parallel-syncs mymaster 1
sentinel auth-pass mymaster test@dbuser2018
sentinel failover-timeout mymaster 180000
sentinel deny-scripts-reconfig yes

 執行如下命令,複製3份redis-sentinel配置文件

cp sentinel.conf sentinel1.conf
cp sentinel.conf sentinel2.conf
cp sentinel.conf sentinel3.conf

3.啟動redis-sentinel

docker-compose up -d

4.查看redis-sentinel是否啟動成功

進入redis-sentinel容器中,查看redis連接狀態

docker exec -it 容器Id bash
redis-cli -p 26379

執行如下命令,查看redis主信息

sentinel master mymaster

顯示帶紅框的信息則表明成功

 執行如下命令,查看從redis信息是否正常

sentinel slaves mymaster

 顯示如下表明正常

四.測試主redis掛了之後,哨兵能否正常選舉redis

使用如下命令,停掉主redis.   [停掉容器也可以使用容器對應的NAMES來停掉]

docker stop redis-master

顯示紅框則表明redis已經停了

 查看redis-sentinel日誌,看其將那個redis選舉為主,如下,其將埠位6381的redis選舉為主

測試埠號為6381的redis是否具備寫功能,如下則表明成功

至此,redis一主二從三哨兵模式部署成功.文中如有不妥,請在評論區留言,我將進行修改以免誤人子弟--

碼字不易,喜歡的點個贊再走

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、前言 在之前學習 Vue 基礎知識點的文章中,我們還是採用傳統的方式,通過在 html 頁面上引用 vue.js 這個文件,從而將 Vue 引入到我們的項目開發中。伴隨著 Node.js 的出現,以及 React、Angular、Vue 這類的前端 MVVM 框架的發展,前端越來越像後端靠攏,前 ...
  • 1. (1)python下多線程的限制以及多進程中傳遞參數的方式 python多線程有個全局解釋器鎖(global interpreter lock),這個鎖的意思是任一時間只能有一個線程使用解釋器,跟單cpu跑多個程式一個意思,大家都是輪著用的,這叫“併發”,不是“並行”。 多進程間共用數據,可以 ...
  • 1.引言 2.關於本書 3.依賴註入和應用切麵 4.容納你的bean 5.spring各個版本的特性 1.引言 如上篇博客所述,打算從Spring作為學習java的切入點,那我們開始吧。 2.關於本書 本書分為4個部分: 2.1 第1部分 介紹Spring容器,以及Spring框架的核心 依賴註入和 ...
  • Python併發編程之多進程 一、什麼是進程 進程:正在進行的一個過程或者說一個任務。而負責執行任務則是cpu。 進程是資源分配的基本單位 進程有:代碼段,數據段,進程式控制制塊(PCB)組成 二、進程與程式的區別 程式僅僅只是一堆代碼而已,而進程指的是程式的運行過程。 舉例: 想象一位有一手好廚藝的計 ...
  • 一、標識符 1.標識符定義:在java源程式中凡是可以自己命名的單詞 2.標識符可以標識什麼元素? (1)類名(2)方法名(3)變數名(4)介面名(5)常量名 等等 3.標識符的命名要求 (1)一個合法的標識符只能由“數字、字母、下劃線、美元符號”來組成,不能含有其他符號。 (2)不能數字開頭 (3 ...
  • 一、Shiro簡介 1、基礎概念 Apache Shiro是一個強大且易用的Java安全框架,執行身份驗證、授權、密碼和會話管理。作為一款安全框架Shiro的設計相當巧妙。Shiro的應用不依賴任何容器,它不僅可以在JavaEE下使用,還可以應用在JavaSE環境中。 2、核心角色 1)Subjec ...
  • 總結理解的模板方法設計模式及抽象類 (菜鳥一隻,若有什麼侵權或者不足之處,請指出,謝謝) 模板方法設計模式: 在父類中定義一個總體的演算法骨架,而將一些具體的實現步驟放在到子類中,因為不同的子類實現細節不同 模板方法使得子類可以在不改變演算法框架的情況下,只需要重新定義演算法的某些實現步驟(藉助於抽象類實 ...
  • 1.JWT簡介 JSON Web Token(縮寫 JWT),是目前最流行的跨域認證解決方案。 2.JWT的原理 JWT的原理是,伺服器認證以後,生成一個JSON格式的對象,發回給客戶端,就像下麵這樣. 以後,客戶端與服務端通信的時候,都要發回這個 JSON 對象。伺服器完全只靠這個對象認定用戶身份 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...