三台伺服器使用docker搭建redis一主二從三哨兵,概念-搭建-整合springboot

来源:https://www.cnblogs.com/wang1221/archive/2023/01/03/17022603.html
-Advertisement-
Play Games

一、前言 redis在我們企業級開發中是很常見的,但是單個redis不能保證我們的穩定使用,所以我們要建立一個集群。 redis有兩種高可用的方案: High availability with Redis Sentinel(哨兵) Scaling with Redis Cluster(分片集群) ...


一、前言

redis在我們企業級開發中是很常見的,但是單個redis不能保證我們的穩定使用,所以我們要建立一個集群。
redis有兩種高可用的方案:

  • High availability with Redis Sentinel(哨兵)
  • Scaling with Redis Cluster(分片集群)

第一個就是我們本次的要搭建的,就是高可用的哨兵,主redis掛掉,哨兵會進行投票進行故障轉移
第二個就是分片集群,哨兵的一個缺點就是只能存在一個master節點,寫的效率太低。分片集群就是解決哨兵的問題,可以水平擴展,提高redis的性能!

哨兵最低配是三哨兵,以奇數遞增。
分片集群最低配是三主三從。

小編之前寫過一篇在一臺機器上搭建的文章,大家有興趣可以先去體驗一下,實際生產上不會讓你一臺機器上;也沒有任何意義,伺服器掛了,再多的集群也全部掛掉了!!

docker compose搭建redis7.0.4高可用一主二從三哨兵集群並整合SpringBoot

二、準備

首先我們要準備:
三台伺服器(沒有的條件的搭三個虛擬機),巧了小編就是虛擬機哈!

三台機器的ip和名稱在表格裡整理一下!

ip redis節點名稱 sentinel節點名稱
192.168.239.131 redis-master redis-sentinel-1
192.168.239.130 redis-slave-1 redis-sentinel-2
192.168.239.128 redis-slave-2 redis-sentinel-3

三、Sentinel概念

Redis Sentinel 在不使用Redis Cluster時為 Redis 提供高可用性

Sentinel功能的完整列表:

  • 監控:Sentinel 不斷檢查您的主實例和副本實例是否按預期工作。
  • 通知:Sentinel 可以通過 API 通知系統管理員或其他電腦程式,其中一個受監控的 Redis 實例出現問題。
  • 自動故障轉移:如果 master 沒有按預期工作,Sentinel 可以啟動一個故障轉移過程,其中一個副本被提升為 master,其他額外的副本被重新配置為使用新的 master,並且使用 Redis 伺服器的應用程式被告知要使用的新地址連接時。
  • 自動更新配置:Sentinel 充當客戶端服務發現的權威來源:客戶端連接到 Sentinels 以詢問負責給定服務的當前 Redis master 的地址。如果發生故障轉移,Sentinels 將報告新地址。

官方哨兵搭建條件:

  • 您至少需要三個 Sentinel 實例才能進行可靠的部署。
  • 三個 Sentinel 實例應該放置在被認為以獨立方式發生故障的電腦或虛擬機中。因此,例如在不同可用區上執行的不同物理伺服器或虛擬機

詳細介紹和使用:請見官網 --->官網詳細文檔

四、一主二從搭建

話不多說,咱們直接開始搭建哈!

1. 創建掛載目錄

三台機器上新建目錄:
首先我們開啟三個xshell視窗,然後同時操作三個視窗創建
在這裡插入圖片描述
然後再左下角選擇發送到全部視窗!

cd /
mkdir mydata
cd /mydata
mkdir redis
cd redis
mkdir data
mkdir conf
cd conf

2. 在192.168.239.131機器上編輯文件

vim redis.conf

輸入以下內容:

# 任何都可以連接redis
bind 0.0.0.0
# 配置master密碼
requirepass 123456
# 宕機後成為從要連接master的密碼
masterauth 123456
# 開啟持久化
appendonly yes

在這裡插入圖片描述

3. 在192.168.239.130機器上編輯文件

vim redis.conf

輸入以下內容:

# 配置master的ip和埠號
replicaof 192.168.239.131 6379
# 任何都可以連接redis
bind 0.0.0.0
# 成為master後的密碼
requirepass 123456
# 連接master密碼
masterauth 123456
# 開啟持久化
appendonly yes

在這裡插入圖片描述

4. 在192.168.239.128機器上編輯文件

vim redis.conf

輸入以下內容:

# 配置master的ip和埠號
replicaof 192.168.239.131 6379
# 任何都可以連接redis
bind 0.0.0.0
# 成為master後的密碼
requirepass 123456
# 連接master密碼
masterauth 123456
# 開啟持久化
appendonly yes

5. 192.168.239.131啟動redis

docker run -p 6379:6379 --name redis-master \
-v /mydata/redis/data:/usr/local/etc/redis/data \
-v /mydata/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf \
-d redis redis-server /usr/local/etc/redis/redis.conf

查看啟動日誌:

docker logs -f redis-master

在這裡插入圖片描述

6. 192.168.239.130啟動redis

docker run -p 6379:6379 --name redis-slave-1 \
-v /mydata/redis/data:/usr/local/etc/redis/data \
-v /mydata/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf \
-d redis redis-server /usr/local/etc/redis/redis.conf

可以看到已經連接到master節點了!
在這裡插入圖片描述

7. 192.168.239.128啟動redis

docker run -p 6379:6379 --name redis-slave-2 \
-v /mydata/redis/data:/usr/local/etc/redis/data \
-v /mydata/redis/conf/redis.conf:/usr/local/etc/redis/redis.conf \
-d redis redis-server /usr/local/etc/redis/redis.conf

在這裡插入圖片描述

8. 進入192.168.239.130容器查看

我們查看master日誌,可以看到兩個從節點已經加入進來了!
在這裡插入圖片描述

我們進入容器進行在次查看:

docker exec -it redis-master /bin/bash

連接redis:

redis-cli

登錄redis

auth 123456

在這裡插入圖片描述

查看從節點:

info

也是可以看到有兩個從節點!

在這裡插入圖片描述

五、搭建三哨兵sentinel

1. 創建掛載目錄

還是三個虛擬機一起創建

mkdir sentinel
cd sentinel
vim sentinel.conf

輸入下麵內容:

port 26379
sentinel monitor redis-master 192.168.239.131 6379 2
sentinel auth-pass redis-master 123456
sentinel down-after-milliseconds redis-master 6000
sentinel parallel-syncs redis-master 1
sentinel failover-timeout redis-master 6000

第二行:Redis 監控一個名為redis-master的redis集群,我們可以隨意寫;後面就是ip,我們宿主機的ip即可,埠為主redis的埠;2為哨兵投票的票數,當主redis宕機,三個哨兵必須兩個哨兵都投票的redis才會變為主!!
第三行:配置master的密碼
第四行:Sentinel判斷實例進入主觀下線所需的時間,毫秒單位。
第五行:限制在一次故障轉移之後,每次向新的主節點同時發起複制操作節點個數,越大效率越慢。
第六行:在指定的時間內未能完成failover故障轉移,則任務故障轉移失敗。

在這裡插入圖片描述

2. 運行192.168.239.131哨兵

docker run -p 26379:26379 --name redis-sentinel-1 \
-v /mydata/redis/sentinel/sentinel.conf:/usr/local/etc/redis/sentinel.conf \
-d redis redis-sentinel /usr/local/etc/redis/sentinel.conf

3. 運行192.168.239.130哨兵

docker run -p 26379:26379 --name redis-sentinel-2 \
-v /mydata/redis/sentinel/sentinel.conf:/usr/local/etc/redis/sentinel.conf \
-d redis redis-sentinel /usr/local/etc/redis/sentinel.conf

3. 運行192.168.239.128哨兵

docker run -p 26379:26379 --name redis-sentinel-3 \
-v /mydata/redis/sentinel/sentinel.conf:/usr/local/etc/redis/sentinel.conf \
-d redis redis-sentinel /usr/local/etc/redis/sentinel.conf

4. 待解決問題

這裡創建三個哨兵,查看卻是有四個,不知道什麼問題,換了虛擬機還是不行!有大佬懂的可以分享一下哈!!

在這裡插入圖片描述

六、測試主從和故障轉移

1. 測試主從複製

master節點創建一個鍵值對:

set a b

在這裡插入圖片描述

從查看key是否存在:

get a

在這裡插入圖片描述
主從沒有問題哈!

2. 測試故障轉移

我們把master停掉,查看一個哨兵的日誌:

docker stop redis-master
docker logs -f redis-sentinel-1 

我們看到192.168.239.130成為master!

在這裡插入圖片描述
重新啟動原來的master:

docker restart redis-master 

在這裡插入圖片描述

故障轉移成功!!

七、整合springboot

1. 導入依賴

小編的springboot版本為:2.7.4

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

2. yml配置

password密碼和sentinel同級,不然找不到密碼,驗證失敗

server:
  port: 8087

spring:
  redis:
    # 密碼和sentinel同級,不然找不到密碼,驗證失敗
    password: 123456
    sentinel:
      # sentinel.conf里的集群名稱
      master: my-master
      # 我們只需要連哨兵即可,哨兵內部會幫我們找到redis
      nodes:
        - 192.168.239.131:26379
        - 192.168.239.130:26379
        - 192.168.239.128:26379

3. json序列化配置

/**
 * @author wangzhenjun
 * @date 2022/11/24 10:37
 */
@Configuration
public class RedisConfig {

    @Bean
    @SuppressWarnings(value = { "unchecked", "rawtypes" })
    public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory connectionFactory)
    {
        RedisTemplate<Object, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(connectionFactory);
        Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer(Object.class);

        // 使用StringRedisSerializer來序列化和反序列化redis的key值
        template.setKeySerializer(new StringRedisSerializer());
        template.setValueSerializer(serializer);

        // Hash的key也採用StringRedisSerializer的序列化方式
        template.setHashKeySerializer(new StringRedisSerializer());
        template.setHashValueSerializer(serializer);

        template.afterPropertiesSet();
        return template;
    }
}

4. 新建controller測試

/**
 * @author wangzhenjun
 * @date 2022/11/24 10:37
 */
@RestController
public class TestController {

    @Autowired
    private RedisTemplate redisTemplate;

    @GetMapping("/redis")
    public void saveRedis(){
        redisTemplate.opsForValue().set("test","看到我就成功了");
    }
}

5. 測試

http://localhost:8087/test/redis

在這裡插入圖片描述

6. 查看redis

在這裡插入圖片描述

八、總結

經過一天的搭建,終於完成了,雖然不是完美的,但是大體功能是沒有問題的!但是不影響故障轉移和主從複製!

唯一的遺憾:三個哨兵,查看就是四個!從第三個哨兵加入後變為4個!

如果對你有幫助,還請不要吝嗇您的發財小手,你的一鍵三連是我寫作的動力,謝謝大家哈!!


可以看下一小編的微信公眾號,文章首發看,歡迎關註,一起交流哈!!


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

-Advertisement-
Play Games
更多相關文章
  • 摘要:究竟什麼樣的系統算是高併發系統?今天,我們就一起解密高併發業務場景下典型的秒殺系統的架構。 本文分享自華為雲社區《【高併發】秒殺系統架構解密,不是所有的秒殺都是秒殺(升級版)!!》,作者: 冰 河。 究竟什麼樣的系統算是高併發系統?今天,我們就一起解密高併發業務場景下典型的秒殺系統的架構。 電 ...
  • 流程式控制制 用戶交互Scanner Scanner類可以實現電腦與人的交互。java.util.Scanner 是 Java5 的新特征,我們可以通過 Scanner 類來獲取用戶的輸入。 Scanner 類的 next() 與 nextLine() 方法獲取輸入的字元串,在讀取前我們一般需要 使用 ...
  • 同步和非同步 同步和非同步是指程式的執行方式。在同步執行中,程式會按順序一個接一個地執行任務,直到當前任務完成。而在非同步執行中,程式會在等待當前任務完成的同時,執行其他任務。 同步執行意味著程式會阻塞,等待任務完成,而非同步執行則意味著程式不會阻塞,可以同時執行多個任務。 同步和非同步的選擇取決於你的程式需 ...
  • 摘要 本文主要講述了一個 http request 請求從發出到收到 response 的整個生命周期,希望可以通過對整個流程的一個描述來梳理清楚五層網路協議的定義以及各層之間是如何協作的。 使用Golang發起一個HTTP請求 對於後端來說通過 http 請求來進行遠程調用是再尋常不過的事了,以 ...
  • 1. 拷貝和拷貝構造函數 拷貝和複製是一個意思,對應的英文單詞都是copy。對於電腦來說,拷貝是指用一份原有的、已經存在的數據創建出一份新的數據,最終的結果是多了一份相同的數據。例如,將 Word 文檔拷貝到U盤去複印店列印,將 D 盤的圖片拷貝到桌面以方便瀏覽,將重要的文件上傳到百度網盤以防止丟 ...
  • 家居網購項目實現013 以下皆為部分代碼,詳見 https://github.com/liyuelian/furniture_mall.git 32.功能30-會員不能登錄後臺管理 32.1需求分析/圖解 管理員admin登錄後,可以訪問所有頁面 會員登錄後,不能訪問後臺管理相關頁面,其他頁面可以訪 ...
  • 大家好,我是車轍,我的掘金小冊《SkyWalking:應用監控和鏈路跟蹤》已經上線啦,這是我的第一本電子書,歡迎大家訂閱。 整整好是9月的最後一天下午,能按耐住衝動的是少之又少,至於原因嘛你懂的。趕高鐵的準備趕高鐵,沒趕高鐵的也假裝趕高鐵。特別是開發同學,腦門上就差貼張紙條:別打擾我。 現在離跑路時 ...
  • 大多數開發者可能都用過 Postman,根據其官網的介紹:Postman 是一個用於構建和使用 API 的 API 平臺,簡化了 API 生命周期的每個步驟,提供更便捷的團隊協作,因此可以更快地創建更好的 API。這裡的 API,除了我們常用的 HTTP API 之外,還包括 Websocket(B ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...