使用SpringBoot整合redis多主多从集群

news2024/11/25 9:26:48

SpringBoot整合Redis多主多从集群

  • 环境准备
  • SpringBoot整合Redis集群
    • 新建项目
    • 修改SpringBoot配置文件
    • 编写代码测试
      • 编写DTO
      • 编写Controller
    • 测试编写的代码

环境准备

首先我们需要准备一套redis集群,可以参考我写的文章:https://blog.csdn.net/m0_51510236/article/details/132684529。这次我已经准备好了一个集群,如图(一个多主多从的redis集群):
在这里插入图片描述

本片文章使用的代码仓库地址:https://gitcode.net/m0_51510236/redis-cluster-example

SpringBoot整合Redis集群

新建项目

我们来新建一个SpringBoot项目来连接这个集群,来到spring initializr进行初始化:
在这里插入图片描述

然后我们将其导入开发工具,如图:
在这里插入图片描述

修改SpringBoot配置文件

编辑 application.yaml 文件,文件内容为:

# 设置端口
server:
  port: 8080

spring:
  redis:
    cluster:
      # 设置redis集群当中都有哪些节点,注意修改为你自己的节点地址
      nodes:
        - 192.168.1.171:6379
        - 192.168.1.172:6379
        - 192.168.1.173:6379
        - 192.168.1.174:6379
        - 192.168.1.175:6379
        - 192.168.1.176:6379

编写代码测试

我们将编写一个控制器来测试这个集群

编写DTO

我们先编写一个存储到redis的DTO类 RedisValueDTO.java

package city.yueyang.redis.entity;

import java.io.Serializable;

/**
 * <p>
 * 存储Redis值类型的数据传输类
 * </p>
 *
 * @author XiaoHH
 * @version 1.0.0
 * @date 2023-09-06 星期三 11:21:28
 * @file RedisValueDTO.java
 */
public class RedisValueDTO implements Serializable {

    /**
     * Redis的Key
     */
    private String key;

    /**
     * 设置到Redis当中的值
     */
    private String value;

    public String getKey() {
        return key;
    }

    public void setKey(String key) {
        this.key = key;
    }

    public String getValue() {
        return value;
    }

    public void setValue(String value) {
        this.value = value;
    }
}

编写Controller

编写一个可以设置和获取redis值的Controller类 RedisController.java

package city.yueyang.redis.controller;

import city.yueyang.redis.entity.RedisValueDTO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.*;

/**
 * <p>
 * 操作Redis的Controller
 * </p>
 *
 * @author XiaoHH
 * @version 1.0.0
 * @date 2023-09-06 星期三 11:49:01
 * @file RedisController.java
 */
@RestController
@RequestMapping("/redis")
public class RedisController {

    /**
     * 注入Redis的操作对象
     */
    @Autowired
    private RedisTemplate<String, String> redisTemplate;

    /**
     * 设置一个值到Redis当中
     *
     * @param value 设置的内容对象
     * @return 返回Success
     */
    @PostMapping
    public String set(@RequestBody RedisValueDTO value) {
        this.redisTemplate.opsForValue().set(value.getKey(), value.getValue());
        return "Success";
    }

    /**
     * 根据key在Redis当中获取一个值
     *
     * @param key redis的key
     * @return 缓存当中的值
     */
    @GetMapping("/{key}")
    public String get(@PathVariable("key") String key) {
        return this.redisTemplate.opsForValue().get(key);
    }
}

此时项目结构为:
在这里插入图片描述

代码仓库地址:https://gitcode.net/m0_51510236/redis-cluster-example

测试编写的代码

我们直接使用开发工具 idea 自带的http工具进行测试吧,测试代码如下:

### 设置的值的内容
POST http://localhost:8080/redis
Content-Type: application/json

{
  "key": "k1",
  "value": "v1"
}

### 获取值的内容
GET http://localhost:8080/redis/k1

我们测试第一个设置值,可以看到返回Success:
在这里插入图片描述

我们测试第一个获取值的内容,可以看到成功的获取了我们设置的值 v1
在这里插入图片描述

SpringBoot整合Redis就到此结束了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/980568.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

对于“微软的亲儿子“汇编真的什么都不算吗?

今日话题&#xff0c;汇编真的不如人称“微软的亲儿子“的C语言吗&#xff1f;一位毕业生分享了他的见解。他学习了汇编和C语言&#xff0c;随后加入嵌入式企业。他发现&#xff0c;C语言由于可移植性、开发效率和可读性更广泛适用。然而&#xff0c;在某些情况下&#xff0c;汇…

BRAM/URAM资源介绍

BRAM/URAM资源简介 Bram和URAM都是FPGA&#xff08;现场可编程门阵列&#xff09;中的RAM资源。 Bram是Block RAM的缩写&#xff0c;是Xilinx FPGA中常见的RAM资源之一&#xff0c;也是最常用的资源之一。它是一种单独的RAM模块&#xff0c;通常用于存储大量的数据&#xff0…

测评自养号的优势和弊端有哪些?

做跨境电商平台的都知道&#xff0c;补单测评是提高销量的常用策略之一&#xff0c;无论是哪个平台的新店铺或新产品&#xff0c;很难依靠自然流量取得好的销售成绩&#xff0c;因此许多跨境卖家选择进行测评&#xff0c;以提高产品的排名、权重和销量&#xff0c;并增加订单量…

flink cdc多种数据源安装、配置与验证

搜索 flink cdc多种数据源安装、配置与验证 文章目录 1. 前言2. 数据源安装与配置2.1 MySQL2.1.1 安装2.1.2 CDC 配置2.2 Postgresql2.2.1 安装2.2.2 CDC 配置2.3 Oracle2.3.1 安装2.3.2 CDC 配置2.4 SQLServer2.4.1 安装2.4.2 CDC 配置3. 验证3.1 Flink版本与CDC版本的对应关系…

win10系统启用win32长路径

Step1、在系统开始 输入框中输入: gpedit.msc&#xff0c;然后回车键。 Step2、在本地计算机 策略中&#xff0c;选择: 计算机配置 -> 管理模板 Step3、然后选择: 系统 -> 文件系统 Step4、窗口中上靠右侧有 启用Win32长路径&#xff0c;如下图: Step5、双击 启用Win…

最长递增子序列

题目链接 最长递增子序列 题目描述 注意点 子序列 是由数组派生而来的序列&#xff0c;删除&#xff08;或不删除&#xff09;数组中的元素而不改变其余元素的顺序 解答思路 初始想到使用动态规划解决本题&#xff0c;对于任意位置元素&#xff0c;找到前面比其值更小的元…

MyBatis配置及单表操作

文章目录 一. MyBatis概述二. MyBatis项目的创建1. 准备一个数据表2. 创建项目 三. MyBatis的使用1. 基本使用2. SpringBoot单元测试 四. 使用MyBatis实现单表操作1. 查询2. 修改3. 删除4. 新增 五. 基于注解完成SQL 一. MyBatis概述 MyBatis 是一款优秀的持久层框架&#xff…

Python学习 -- datetime模块

当涉及到处理日期和时间数据时&#xff0c;Python的datetime模块提供了一系列类来帮助您执行各种操作。以下是各个类及其常用方法的详细介绍&#xff1a; date 类​ date 类表示一个年、月、日的日期对象。以下是一些常用的 date 类方法&#xff1a; date.today() 获取当前…

rtmp推流异常分析

问题描述 向srs媒体服务上推送rtmp流&#xff0c;推送失败 分析过程 srs日志分析 从日志中看到发生错误时层次调用关系 [2023-09-05 11:10:29.933][Error][13594][9w5og10q][11] serve error code3001 : service cycle : rtmp: stream service : rtmp: receive thread : ha…

Spring系列文章3:基于注解方式依赖注入

和XML 配置文件一样&#xff0c;注解本身并不能执行&#xff0c;注解本身仅仅只是做一个标记&#xff0c;具体的功能是框架检测 到注解标记的位置&#xff0c;然后针对这个位置按照注解标记的功能来执行具体操作&#xff0c;本质上所有操作都是Java代码来完成的&#xff0c;XML…

windows安装Oracle19c安装

windows安装Oracle19c安装 百度云安装包地址&#xff1a;链接&#xff1a;https://pan.baidu.com/s/11XvBN8Zqb7jbhugP88IHRw 提取码&#xff1a;ybsy 官网下载地址&#xff1a;https://www.oracle.com/database/technologies/oracle-database-software-downloads.html 下载…

基于vue3和element-plus的省市区级联组件

git地址&#xff1a;https://github.com/ht-sauce/elui-china-area-dht 使用:npm i elui-china-area-dht 默认使用 使用方法 <template><div class"app"><!--默认使用--><elui-china-area-dht change"onChange"></elui-china…

【android12-linux-5.1】【ST芯片】【RK3588】【LSM6DSR】HAL源码分析

一、环境介绍 RK3588主板搭载Android12操作系统,内核是Linux5.10,使用ST的六轴传感器LSM6DSR芯片。 二、芯片介绍 LSM6DSR是一款加速度和角速度(陀螺仪)六轴传感器,还内置了一个温度传感器。该芯片可以选择I2C,SPI通讯,还有可编程终端,可以后置摄像头等设备,功能是很…

MySQL阻塞与死锁

MySQL阻塞与死锁 阻塞 因为不同锁之间的兼容性关系&#xff0c;在有些时刻一个事务中的锁需要等待另一个事务中的锁释放它所占用的资源&#xff0c;这就是阻塞。 # 查看等待时间 show variables like innodb_lock_wait_timeout; SETinnodb_lock_wait_timeout60; # 是否在等待…

深度学习面试八股文(2023.9.06持续更新)

一、优化器 1、SGD是什么&#xff1f; 批梯度下降&#xff08;Batch gradient descent&#xff09;&#xff1a;遍历全部数据集算一次损失函数&#xff0c;计算量开销大&#xff0c;计算速度慢&#xff0c;不支持在线学习。随机梯度下降&#xff08;Stochastic gradient desc…

【HTML/CSS】入门导学篇

本文属于HTML/CSS专栏文章&#xff0c;适合WEB前端开发入门学习&#xff0c;如果有所帮助请一键三连支持&#xff0c;对博主系列文章感兴趣点击下方专栏了解详细。 本文内容出自B站pink老师的前端入门教程&#xff0c;感谢pink老师&#xff01;&#xff01;&#xff01; 视频链…

【ARM CoreLink 系列 1 -- CoreLink 系列 产品介绍】

文章目录 ARM CoreLink 介绍ARM CoreLink InterconnectARM CoreLink 处理器外设ARM CoreLink Memory Controllers ARM CoreLink 介绍 ARM的CoreLink系列产品是一套能够进行高效互联的组件和工具&#xff0c;它们用于构建高性能、低功耗的嵌入式和消费电子设备。CoreLink产品系…

Mac MySQL初始登录root报错access denied解决方法

如图&#xff0c;当在mac m2上首次安装mysql后尝试登录root用户时&#xff0c;无论输入什么样的密码&#xff0c;或者直接回车键&#xff0c;都会显示access denied for user rootlocalhost。同时win和ubuntu也出现了一模一样的问题&#xff0c;先记录一下mac的解决方法。 参考…

Sigrity仿真报错:找不到电容的S参数?

很多电子工程师会选择使用Sigrity软件进行高速PCB信号仿真&#xff0c;但在使用过程可能会遇见报错情况&#xff0c;其中之一是提示找不到电容的S参数&#xff0c;那么如何解决这个问题&#xff1f; 一般来说&#xff0c;S参数的全称为Scatter参数&#xff0c;即散射参数&#…

STM32单片机OLED贪吃蛇游戏记分计时

实践制作DIY- GC00165---OLED贪吃蛇游戏 一、功能说明&#xff1a; 基于STM32单片机设计---OLED贪吃蛇游戏 二、功能说明&#xff1a; STM32F103C系列最小系统板0.96寸OLED显示器上、下、左、右4个按键 1.通过OLED配合按键实现贪吃蛇游戏 2.可以上下左右移动。 3.可以统计显…