pbootcms网站模板|日韩1区2区|织梦模板||网站源码|日韩1区2区|jquery建站特效-html5模板网

SpringBoot+Redis哨兵模式的實現

本文主要介紹了SpringBoot+Redis哨兵模式的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

最近學習到了Redis的哨兵模式,光看視頻還不行,需要自己動手實現一遍才能加深映像,特此記錄。

由于沒有真實的服務器可以供我操作,所以在虛擬機上啟動了3個redis服務,分別占用7001、7002、7003端口。

Redis下載安裝不多贅述,只在這里記錄一下配置。

首先在tmp目錄下創建3個文件夾:

cd /tmp
mkdir 7001 7002 7003

然后將redis的配置文件redis.conf拷貝到剛剛創建的3個文件夾下

cp redis-6.2.6/redis.conf /tmp/7001
cp redis-6.2.6/redis.conf /tmp/7002
cp redis-6.2.6/redis.conf /tmp/7003

接著修改這3個配置文件

vi redise.conf

找到端口,redis默認端口是6379,這里分別將端口改為7001、7002和7003

然后修改dir,redis持久化文件保存的路徑,分別改為對應的路徑

 接著注釋掉bind并且修改protected-mode為no

redis默認不允許遠程連接,修改這2項配置允許我們遠程連接

最后在配置文件第一行加上 replica-announce-ip  #{ip}

注意:這里#{ip}填自己的ip地址

由于是在虛擬機安裝的redis,會有多個ip,這里寫明ip防止找不到

3個配置文件都改完后,cd 到對應的目錄啟動redis

 3個服務都啟動后,連接7002的redis

redis-cli -p 7002

輸入命令,搭建主從集群,讓7002成為7001的從節點

REPLICAOF #{ip} 7001

注意:這里#{ip}填自己的ip地址

同理,7003也這樣操作一遍,這樣就搭建好了以7001為主節點,7002和7003位從節點的主從集群模式。

需要注意的是,以命令形式搭建的主從集群,重啟后就失效了,想要持久保持可以在配置文件里配置,這里從簡就不貼了。

上述操作完成后,接著在tmp目錄下創建3個新文件夾

mkdir s1 s2 s3

cd到s1目錄,創建文件sentinel.conf,這個文件也可以從redis的目錄中拷貝。

編寫文件配置

# sentinel端口
port 27001
#工作路徑
dir "/tmp/s1"
# 哨兵監控的master,主從配置一樣,在進行主從切換時7001會變成當前的master端口,最后的2為客觀判斷主節# 點下線的節點個數
sentinel monitor mymaster #{ip} 7001 2
# master或slave多長時間不能使用后標記為s_down狀態
sentinel down-after-milliseconds mymaster 5000
#若sentinel在該配置值內未能完成failover操作(即故障時master/slave自動切換),
#則認為本次failover失敗
sentinel failover-timeout mymaster 60000

注意:這里#{ip}填自己的ip地址

然后將sentinel.conf文件cp到s2和s3路徑下,只用修改port和dir為各自的配置

然后分別在各自路徑下啟動3個哨兵

redis-sentinel sentinel.conf

 

 由于之前測試了7001關閉服務,哨兵自動切換主節點為7002了,若為第一次啟動,日志和截圖中的會稍有不同。

哨兵模式搭建好后,接著在Java端集成此模式

pom.xml引入最基本的依賴即可

<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-web</artifactId>
     <exclusions><!-- 去掉springboot默認配置 -->
         <exclusion>
              <groupId>org.springframework.boot</groupId>
              <artifactId>spring-boot-starter-logging</artifactId>
         </exclusion>
     </exclusions>
</dependency>
<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
     <groupId>com.alibaba</groupId>
     <artifactId>fastjson</artifactId>
     <version>1.2.73</version>
</dependency>

application.xml

spring:
  redis:
    sentinel:
      master: mymaster
      nodes:
        - #{ip}:27001
        - #{ip}:27002
        - #{ip}:27003

注意:這里#{ip}填自己的ip地址

在一個配置類里注入一個bean,實現redis讀寫分離,配置從redis讀數據時優先從從節點讀取

package com.wl.demo.config;
 
import com.alibaba.fastjson.serializer.SerializerFeature;
import com.alibaba.fastjson.support.config.FastJsonConfig;
import com.alibaba.fastjson.support.spring.FastJsonRedisSerializer;
import io.lettuce.core.ReadFrom;
import org.springframework.boot.autoconfigure.data.redis.LettuceClientConfigurationBuilderCustomizer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.StringRedisSerializer;
 
/**
 * @author wl
 * @date 2022/3/28
 */
@Configuration
public class RedisConfig {
 
    @Bean
    public LettuceClientConfigurationBuilderCustomizer lettuceClientConfigurationBuilderCustomizer() {
        return builder -> builder.readFrom(ReadFrom.REPLICA_PREFERRED);
    }
 
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) {
        RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(connectionFactory);
 
        FastJsonRedisSerializer<Object> fastJsonRedisSerializer = new FastJsonRedisSerializer<>(Object.class);
        FastJsonConfig fastJsonConfig = fastJsonRedisSerializer.getFastJsonConfig();
        SerializerFeature[] serializerFeatures = new SerializerFeature[] {SerializerFeature.WriteDateUseDateFormat, SerializerFeature.WriteMapNullValue};
        fastJsonConfig.setSerializerFeatures(serializerFeatures);
        StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
 
        redisTemplate.setKeySerializer(stringRedisSerializer);
        redisTemplate.setHashKeySerializer(stringRedisSerializer);
        redisTemplate.setHashValueSerializer(fastJsonRedisSerializer);
        redisTemplate.setValueSerializer(fastJsonRedisSerializer);
        redisTemplate.setEnableTransactionSupport(true);
 
        redisTemplate.afterPropertiesSet();
 
        return redisTemplate;
    }
}

編寫一個測試接口

package com.wl.demo.controller;
 
import com.wl.demo.common.result.HttpResult;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
 
/**
 * @author wl
 * @date 2022/4/14
 */
@RestController
public class TestController {
 
    private final StringRedisTemplate stringRedisTemplate;
 
    @Autowired
    public TestController(StringRedisTemplate stringRedisTemplate) {
        this.stringRedisTemplate = stringRedisTemplate;
    }
 
    @GetMapping("/set/{key}/{value}")
    public HttpResult setValue(@PathVariable("key") String key, @PathVariable("value") String value) {
        stringRedisTemplate.opsForValue().set(key, value);
        return HttpResult.success();
    }
 
    @GetMapping("/get/{key}")
    public HttpResult getValue(@PathVariable("key") String key) {
        return HttpResult.success(stringRedisTemplate.opsForValue().get(key));
    }
}

啟動springboot,調用set接口

 查看redis

7002主節點有值了,并且它的從節點也同步到了數據

 然后調用get接口

 數據也成功獲取到了

最后測試一下哨兵自動切換主從節點,這里關閉7002的redis

 接著查看27002哨兵打印的日志

 從日志中可以看到關閉7002的redis后,哨兵自動將主節點切換到了7001的redis

現在啟動7002的redis

 查看哨兵27001的日志

 可以發現由將7002加入到了自己的從節點中

自此,Redis哨兵模式的簡單搭建就完成了

到此這篇關于SpringBoot+Redis哨兵模式的實現示例的文章就介紹到這了,更多相關SpringBoot Redis哨兵模式內容請搜索html5模板網以前的文章希望大家以后多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

這篇文章主要為大家詳細介紹了如何利用SpringBoot+WebSocket實現即時通訊功能,文中示例代碼講解詳細,對我們學習或工作有一定參考價值,需要的可以參考一下
本文主要介紹了SpringBoot二維碼生成base64并上傳OSS的實現示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學
本文主要介紹了SpringSecurity實現退出登錄和退出處理器,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習
這篇文章主要為大家詳細介紹了Java使用MulticastSocket實現群聊應用程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
這篇文章主要為大家介紹了JavaString中intern方法的原理以及使用。文中通過圖片和示例代碼進行了詳細展示,感興趣的小伙伴可以跟隨小編一起學習一下
這篇文章主要介紹了Spring?boot?整合?Redisson實現分布式鎖并驗證,redisson是官方推薦的分布式鎖實現方案,采用redis自身的原子命令和lua腳本來實現,需要的朋友可以參考下
主站蜘蛛池模板: 「阿尔法设计官网」工业设计_产品设计_产品外观设计 深圳工业设计公司 | 手持式线材张力计-套帽式风量罩-深圳市欧亚精密仪器有限公司 | 威廉希尔WilliamHill·足球(中国)体育官方网站 | 除尘器布袋骨架,除尘器滤袋,除尘器骨架,电磁脉冲阀膜片,卸灰阀,螺旋输送机-泊头市天润环保机械设备有限公司 | 破碎机锤头_合金耐磨锤头_郑州宇耐机械工程技术有限公司 | 油液红外光谱仪-油液监测系统-燃油嗅探仪-上海冉超光电科技有限公司 | 杭州门窗厂家_阳光房_包阳台安装电话-杭州窗猫铝合金门窗 | 济南展厅设计施工_数字化展厅策划设计施工公司_山东锐尚文化传播有限公司 | 澳洁干洗店加盟-洗衣店干洗连锁「澳洁干洗免费一对一贴心服务」 干洗加盟网-洗衣店品牌排行-干洗设备价格-干洗连锁加盟指南 | 保镖公司-私人保镖-深圳保镖公司【环宇兄弟保镖】 | 天助网 - 中小企业全网推广平台_生态整合营销知名服务商_天助网采购优选 | 沙盘模型公司_沙盘模型制作公司_建筑模型公司_工业机械模型制作厂家 | 深圳APP开发公司_软件APP定制开发/外包制作-红匣子科技 | 网站建设-临朐爱采购-抖音运营-山东兆通网络科技 | 建筑消防设施检测系统检测箱-电梯**检测仪器箱-北京宇成伟业科技有限责任公司 | 小港信息港-鹤壁信息港 鹤壁老百姓便民生活信息网站 | 上海办公室装修公司_办公室设计_直营办公装修-羚志悦装 | 减速机_上海宜嘉减速机| 不干胶标签,不干胶标签纸_厂家-山东同力胶粘制品 | GEDORE扭力螺丝刀-GORDON防静电刷-CHEMTRONICS吸锡线-上海卓君电子有限公司 | 北京浩云律师事务所-法律顾问_企业法务_律师顾问_公司顾问 | 四川成都干燥设备_回转筒干燥机_脉冲除尘器_输送设备_热风炉_成都川工星科机电设备有限公司 | 磁粉制动器|张力控制器|气胀轴|伺服纠偏控制器整套厂家--台灵机电官网 | 旅游规划_旅游策划_乡村旅游规划_景区规划设计_旅游规划设计公司-北京绿道联合旅游规划设计有限公司 | 灰板纸、灰底白、硬纸板等纸品生产商-金泊纸业 | 收录网| 手术室净化厂家-成都做医院净化工程的公司-四川华锐-15年特殊科室建设经验 | 注塑_注塑加工_注塑模具_塑胶模具_注塑加工厂家_深圳环科 | 偏心半球阀-电动偏心半球阀-调流调压阀-旋球阀-上欧阀门有限公司 | 糖衣机,除尘式糖衣机,全自动糖衣机,泰州市长江制药机械有限公司 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 飞利浦LED体育场灯具-吸顶式油站灯-飞利浦LED罩棚灯-佛山嘉耀照明有限公司 | 干粉砂浆设备_干混砂浆生产线_腻子粉加工设备_石膏抹灰砂浆生产成套设备厂家_干粉混合设备_砂子烘干机--郑州铭将机械设备有限公司 | 深圳法律咨询【24小时在线】深圳律师咨询免费 | 高清视频编码器,4K音视频编解码器,直播编码器,流媒体服务器,深圳海威视讯技术有限公司 | 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | 艺术涂料|木纹漆施工|稻草漆厂家|马来漆|石桦奴|水泥漆|选加河南天工涂料 | 镀锌钢格栅_热镀锌格栅板_钢格栅板_热镀锌钢格板-安平县昊泽丝网制品有限公司 | 防弹玻璃厂家_防爆炸玻璃_电磁屏蔽玻璃-四川大硅特玻科技有限公司 | 书法培训-高考书法艺考培训班-山东艺霖书法培训凭实力挺进央美 | 广州番禺搬家公司_天河黄埔搬家公司_企业工厂搬迁_日式搬家_广州搬家公司_厚道搬迁搬家公司 | 美缝剂_美缝剂厂家_美缝剂加盟-地老板高端瓷砖美缝剂 |