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";
    }
}
相关推荐
许苑向上1 小时前
MVCC底层原理实现
java·数据库·mvcc原理
组合缺一1 小时前
Solon Cloud Gateway 开发:熟悉 ExContext 及相关接口
java·后端·gateway·solon
一只淡水鱼662 小时前
【spring】集成JWT实现登录验证
java·spring·jwt
忘忧人生2 小时前
docker 部署 java 项目详解
java·docker·容器
null or notnull3 小时前
idea对jar包内容进行反编译
java·ide·intellij-idea·jar
言午coding4 小时前
【性能优化专题系列】利用CompletableFuture优化多接口调用场景下的性能
java·性能优化
缘友一世5 小时前
JAVA设计模式:依赖倒转原则(DIP)在Spring框架中的实践体现
java·spring·依赖倒置原则
何中应5 小时前
从管道符到Java编程
java·spring boot·后端
SummerGao.5 小时前
springboot 调用 c++生成的so库文件
java·c++·.so
组合缺一5 小时前
Solon Cloud Gateway 开发:Route 的过滤器与定制
java·后端·gateway·reactor·solon