java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Redis Java 集成 Spring Boot

Redis Java 集成到 Spring Boot的详细过程

作者:明志学编程

本文介绍了如何使用SpringBoot连接Redis,并展示了如何配置Redis服务地址、创建Controller类以及进行基本的Redis操作,如字符串、列表、集合、哈希和有序集合,感兴趣的朋友跟随小编一起看看吧

一、使用 Spring Boot 连接 Redis 单机

1.创建Spring Boot 项目

2.勾选相关依赖(Dependencies)

3.界面显示

二、配置 Redis 服务地址

1.在 application.yml 中配置

spring:
  data:
    redis:
      host: 127.0.0.1 # 地址
      port: 8888 # 映射的端口号

补充:
Spring Boot 1.x 和 Spring Boot 2.x 中,spring.redis.host 用于配置 Redis 连接属性。
Spring Boot 3.x 中,spring.redis.host 已经弃用。
从 Spring Boot 2.x 开始,引入了 spring.data.redis 作为配置 Redis 连接的方式,并且在 Spring Boot 3.x 中也可以使用 spring.data.redis 进行配置。

2.映射端口号

用Shell8 进行配置,需要一个公网ip

三、创建 Controller 类

1.创建一个 MyController

由于当前只是写简单的测试代码, 我们就不进⾏分层了. 就只创建个简单的 Controller 即可.

@RestController
public class MyController {
 @Autowired
 private StringRedisTemplate redisTemplate;
}

StringRedisTemplate 用来处理文本数据的
继承于RedisTemplate
RedisTemplate 可以处理文本数据也可以处理二进制数据

2.使用 String

@GetMapping("/testString")
@ResponseBody
public String testString() {
    //先清除之前的数据库
    redisTemplate.execute((RedisConnection connection) -> {
        connection.flushAll();
        return null;
    });
    //对原生 redis 又做了进一步封装
    redisTemplate.opsForValue().set("key", "111");
    redisTemplate.opsForValue().set("key2", "222");
    redisTemplate.opsForValue().set("key3", "333");
    String value = redisTemplate.opsForValue().get("key");
    System.out.println("value:" + value);
    return "OK";
}

客户端发送请求(返回OK)表明已经成功

打印日志

3.使用 List

@GetMapping("/testList")
@ResponseBody
public String testList() {
    //先清除之前的数据库
    redisTemplate.execute((RedisConnection connection) -> {
        connection.flushAll();
        return null;
    });
    redisTemplate.opsForList().leftPush("key", "111");
    redisTemplate.opsForList().leftPush("key", "222");
    redisTemplate.opsForList().leftPush("key", "333");
    String value = redisTemplate.opsForList().leftPop("key");
    System.out.println("value: " + value);
    value = redisTemplate.opsForList().leftPop("key");
    System.out.println("value: " + value);
    value = redisTemplate.opsForList().leftPop("key");
    System.out.println("value: " + value);
    return "OK";
}

客户端发送请求(返回OK)表明已经成功

打印日志

4.使用 Set

@GetMapping("/testSet")
@ResponseBody
public String testSet() {
    //先清除之前的数据库
    redisTemplate.execute((RedisConnection connection) -> {
        connection.flushAll();
        return null;
    });
    redisTemplate.opsForSet().add("key", "111", "222", "333");
    Set<String> result = redisTemplate.opsForSet().members("key");
    System.out.println("result: " + result);
    Boolean exists = redisTemplate.opsForSet().isMember("key", "111");
    System.out.println("existe: " + exists);
    Long count = redisTemplate.opsForSet().size("key");
    System.out.println("count: " + count);
    redisTemplate.opsForSet().remove("key", "111", "222");
    result = redisTemplate.opsForSet().members("key");
    System.out.println("result: " + result);
    return "OK";
}

客户端发送请求(返回OK)表明已经成功

打印日志

5.使用 Hash

@GetMapping("/testHash")
@ResponseBody
public String testHash() {
    //先清除之前的数据库
    redisTemplate.execute((RedisConnection connection) -> {
        connection.flushAll();
        return null;
    });
    redisTemplate.opsForHash().put("key", "f1", "111");
    Map<String, String> map = new HashMap<>();
    map.put("f2", "222");
    map.put("f3", "333");
    redisTemplate.opsForHash().putAll("key", map);
    String value = (String) redisTemplate.opsForHash().get("key", "f1");
    System.out.println("value: " + value);
    Boolean exists = redisTemplate.opsForHash().hasKey("key", "f1");
    System.out.println("exists: " + exists);
    redisTemplate.opsForHash().delete("key", "f1", "f2");
    Long len = redisTemplate.opsForHash().size("key");
    System.out.println("len: " + len);
    return "OK";
}

客户端发送请求(返回OK)表明已经成功

打印日志

6.使用 ZSet

@GetMapping("/testZSet")
@ResponseBody
public String testZSet() {
    //先清除之前的数据库
    redisTemplate.execute((RedisConnection connection) -> {
        connection.flushAll();
        return null;
    });
    redisTemplate.opsForZSet().add("key", "zhangsan", 10);
    redisTemplate.opsForZSet().add("key", "lisi", 20);
    redisTemplate.opsForZSet().add("key", "wangwu", 30);
    Set<String> members = redisTemplate.opsForZSet().range("key", 0, -1);
    System.out.println("members: " + members);
    Set<ZSetOperations.TypedTuple<String>> membersWithScores = redisTemplate.opsForZSet().rangeWithScores("key", 0, -1);
    System.out.println("membersWithScores: " + membersWithScores);
    Double score = redisTemplate.opsForZSet().score("key", "zhangsan");
    System.out.println("score: " + score);
    redisTemplate.opsForZSet().remove("key", "zhangsan");
    Long size = redisTemplate.opsForZSet().size("key");
    System.out.println("size: " + size);
    Long rank = redisTemplate.opsForZSet().rank("key", "lisi");
    System.out.println("rank: " + rank);
    return "OK";
 }

客户端发送请求(返回OK)表明已经成功

打印日志

四、小结

到此这篇关于Redis Java 集成到 Spring Boot的文章就介绍到这了,更多相关Redis Java 集成到 Spring Boot内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文