SpringBoot 集成 Redis 总结

一、Redis 简介

Redis 是一个开源的内存数据结构存储系统,它可以用作数据库、缓存和消息中间件。Redis 以其高效的性能、丰富的数据结构和简单的 API 而受到广泛关注。它将数据存储在内存中,并可以通过持久化机制将数据保存到硬盘上,以防止数据丢失。

二、Redis 的数据类型

  1. 字符串(String):可以存储任何形式的字符串,如文本、数字等。例如:SET key value
  2. 哈希(Hash):类似于 Java 中的 Map 结构,由键值对组成。例如:HSET hash_key field value
  3. 列表(List):是一个有序的字符串列表,可以在列表的两端进行快速的插入和删除操作。例如:LPUSH list_key value
  4. 集合(Set):是一个无序的、不重复的字符串集合。例如:SADD set_key value
  5. 有序集合(Sorted Set):与集合类似,但每个元素都关联一个分数,可以根据分数进行排序。例如:ZADD sorted_set_key score value

三、Redis 的关键优势

  1. 高性能:Redis 将数据存储在内存中,因此具有非常高的读写速度,可以满足对性能要求较高的应用场景。
  2. 丰富的数据结构:Redis 提供了多种数据结构,可以满足不同的应用需求,使得开发者可以更加灵活地存储和操作数据。
  3. 持久化:Redis 支持两种持久化方式,即 RDB(快照)和 AOF(日志追加),可以将数据持久化到硬盘上,保证数据的安全性。
  4. 高可用性:Redis 可以通过主从复制和哨兵机制实现高可用性,当主节点出现故障时,从节点可以自动切换为主节点,保证服务的不间断。
  5. 支持分布式:Redis 可以很容易地进行分布式部署,通过分片技术可以将数据分布到多个节点上,提高系统的扩展性和性能。

四、SpringBoot 集成 Redis 代码示例

  1. 添加依赖
    pom.xml文件中添加 Redis 依赖:

    <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>
  2. 配置 Redis
    application.properties文件中配置 Redis:

    spring.redis.host=localhost
    spring.redis.port=6379

  3. 使用 Redis
    创建一个RedisService类,用于操作 Redis:

    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.data.redis.core.RedisTemplate;
    import org.springframework.stereotype.Service;

    @Service
    public class RedisService {

     @Autowired
     private RedisTemplate<String, Object> redisTemplate;
    
     public void set(String key, Object value) {
         redisTemplate.opsForValue().set(key, value);
     }
    
     public Object get(String key) {
         return redisTemplate.opsForValue().get(key);
     }
    

    }

在其他地方可以使用RedisService类来操作 Redis:

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class MyController {

    @Autowired
    private RedisService redisService;

    @GetMapping("/set")
    public String setValue() {
        redisService.set("key", "value");
        return "Value set in Redis";
    }

    @GetMapping("/get")
    public String getValue() {
        Object value = redisService.get("key");
        return value!= null? value.toString() : "Value not found in Redis";
    }
}
相关推荐
Algorithm15762 分钟前
JVM是什么,与Java的关系是什么,以及JVM怎么实现的跨平台性
java·开发语言·jvm
遇见你真好。1 小时前
SpringBoot整合quartz定时任务
java·springboot·quartz
一颗甜苞谷1 小时前
开源一款基于 JAVA 的仓库管理系统,支持三方物流和厂内物流,包含 PDA 和 WEB 端的源码
java·开发语言·开源
攻心的子乐1 小时前
idea使用svn
java·ide·intellij-idea
程序员大佬超1 小时前
IDEA解决 properties 文件乱码问题
java·ide·intellij-idea
秋恬意1 小时前
LinkedList 源码分析
java·开发语言·面试
隔窗听雨眠1 小时前
深入理解Redis的四种模式
java·redis·mybatis
lexusv8ls600h1 小时前
微服务设计模式 - 重试模式(Retry Pattern)
java·spring boot·微服务
Viktor_Ye2 小时前
高效数据集成:易仓退款订单与金蝶销售退货单的自动化对接
java·运维·自动化
feilieren2 小时前
leetcode - 684. 冗余连接
java·开发语言·算法