springboot 集成redis哨兵主从

springboot 集成redis哨兵主从

一、环境

spring boot 2.3.12.RELEASE
JDK 1.8
IntelliJ IDEA开发工具
Redis哨兵主从搭建

二、POM文件

pom文件其他忽略,只展示和redis有关系统的依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- 重点:redis依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- 对象池框架,redis依赖 -->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
</dependency>
三、application.yml配置

关于springboot的配置忽略
spring 约定大于配置,对于默认的就可以不用再配置文件中体现

spring:
  redis:
    # redis库
    database: 1
    # redis节点的密码
    password: jwssw
    # 集群配置
    sentinel:
      # 集群哨兵节点配置,多个节点之间用英文逗号分割
      nodes: 127.0.0.1:26379,127.0.0.1:26380,127.0.0.1:26381
      # 主节点名称
      master: mymaster
      # 密码
      password: jwssw
  • 注意如果redis的sentinel配置文件增加了requirepass(访问秘钥),其sentinel节点下必须加上【password】,否则不需要添加。
四、reidsTemplate配置

该配置文件可以直接加载启动类中,因为启动类也是springboot的一种配置类

/**
 * 方法描述: 初始化redis连接
 *
 * @param factory redis连接工厂
 * @return {@link RedisTemplate}
 */
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory factory) {
    // 新建redisTemplate对象
    RedisTemplate<String, Object> template = new RedisTemplate<>();
    // 设置工厂
    template.setConnectionFactory(factory);
    // 键值类型
    template.setKeySerializer(new StringRedisSerializer());
    template.setValueSerializer(new StringRedisSerializer());
    // 返回redisTemplate对象
    return template;
}
五、单元测试(JUnit4)
@RunWith(SpringRunner.class)
@SpringBootTest
public class RedisTest {
    // 注入redisTemplate对象
    @Autowired
    RedisTemplate<String, Object> redisTemplate;

    @Test
    public void setOrGetTest() {
        // redis键值 
        String redisKey = "name";
        // 向redis存放内容
        redisTemplate.opsForValue().set(redisKey, "张三" + new Random().nextInt());
        // 获取redis中的内容并打印
        System.out.println(redisTemplate.opsForValue().get(redisKey));
    }
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中集成Redis主从模式可以通过配置Redis哨兵或者使用Redisson来实现。下面分别介绍这两种方式: 1. 使用Redis哨兵模式: - 添加依赖:在pom.xml文件中添加如下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` - 配置文件:在application.properties或application.yml文件中配置Redis哨兵模式相关信息,例如: ``` spring.redis.sentinel.master=master spring.redis.sentinel.nodes=host1:port1,host2:port2,host3:port3 ``` - 编写代码:使用Spring Data Redis提供的操作接口即可进行Redis的读写操作。 2. 使用Redisson: - 添加依赖:在pom.xml文件中添加如下依赖: ```xml <dependency> <groupId>org.redisson</groupId> <artifactId>redisson-spring-boot-starter</artifactId> <version>3.15.0</version> </dependency> ``` - 配置文件:在application.properties或application.yml文件中配置Redis连接相关信息,例如: ``` spring.redis.host=127.0.0.1 spring.redis.port=6379 ``` - 编写代码:通过Redisson提供的RedissonClient对象来进行Redis的操作,例如: ```java @Autowired private RedissonClient redissonClient; public void setValue(String key, String value) { RMap<String, String> map = redissonClient.getMap("my_map"); map.put(key, value); } ``` 以上是两种集成Redis主从模式的方法,根据实际情况选择适合的方式进行配置和使用。希望对你有帮助!如果还有其他问题,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值