`
234390216
  • 浏览: 10237885 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
博客专栏
A5ee55b9-a463-3d09-9c78-0c0cf33198cd
Oracle基础
浏览量:462835
Ad26f909-6440-35a9-b4e9-9aea825bd38e
springMVC介绍
浏览量:1775911
Ce363057-ae4d-3ee1-bb46-e7b51a722a4b
Mybatis简介
浏览量:1398690
Bdeb91ad-cf8a-3fe9-942a-3710073b4000
Spring整合JMS
浏览量:395130
5cbbde67-7cd5-313c-95c2-4185389601e7
Ehcache简介
浏览量:680144
Cc1c0708-ccc2-3d20-ba47-d40e04440682
Cas简介
浏览量:531108
51592fc3-854c-34f4-9eff-cb82d993ab3a
Spring Securi...
浏览量:1184883
23e1c30e-ef8c-3702-aa3c-e83277ffca91
Spring基础知识
浏览量:468672
4af1c81c-eb9d-365f-b759-07685a32156e
Spring Aop介绍
浏览量:151478
2f926891-9e7a-3ce2-a074-3acb2aaf2584
JAXB简介
浏览量:68321
社区版块
存档分类
最新评论

Spring Boot(10)——使用Redis

阅读更多

使用Redis

Spring Boot提供了spring-boot-starter-data-redis这样一个Starter,通过加入这样一个依赖,会自动配置RedisConnectionFactory,默认是基于Lettuce的实现。然后会基于RedisConnectionFactory自动配置RedisTemplate和基于String操作的StringRedisTemplate。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

默认连接的Redis主机是localhost,端口号是6379。可以通过spring.redis.host指定需要连接的主机,通过spring.redis.port指定需要连接的主机端口号。比如下面指定了需要连接的Redis主机地址是192.168.0.104,端口号是6378。

spring.redis.host=192.168.0.104
spring.redis.port=6378

接着就可以按照Spring Data Redis中使用RedisTemplate和StringRedisTemplate的用法进行Redis的基本操作了。下面的代码中通过StringRedisTemplate设置了key1为一个String类型的缓存,为其指定了值和缓存失效时间。key2为List类型的缓存,每次都从最左边存入一个值,一共存了10个,然后再从Redis中获取key2对应的值依次输出。

@Autowired
private StringRedisTemplate stringRedisTemplate;

public void basicOperation() {
    BoundValueOperations<String, String> boundValueOps = this.stringRedisTemplate.boundValueOps("key1");
    boundValueOps.set("test string value", 60, TimeUnit.MINUTES);
    
    BoundListOperations<String, String> boundListOps = this.stringRedisTemplate.boundListOps("key2");
    for (int i=0; i<10; i++) {
        boundListOps.leftPush("V_" + (i*10 + i+1));
    }
    
    List<String> list = boundListOps.range(0, boundListOps.size());
    list.forEach(System.out::println);
}

Redis中存放Key和Value也可以是Java对象,对象默认会被序列化后再写入到Redis,然后读取的时候会被反序列化。下面的代码就是往Redis中存入Java对象的示例,Key和Value都可以是对象。

@Autowired
private RedisTemplate<Object, Object> redisTemplate;

public void operForUser() {
    User user = new User();
    user.setId(1L);
    user.setUsername("zhangsan");
    user.setName("张三");
    ValueOperations<Object, Object> opsForValue = this.redisTemplate.opsForValue();
    opsForValue.set(user, user);
    
    Object object = opsForValue.get(user);
    System.out.println(object);
    
    System.out.println("================================================");
    
    opsForValue.set("user::" + user.getId(), user);
    
    object = opsForValue.get("user::" + user.getId());
    System.out.println(object);
    
}

@Data
public static class User implements Serializable {
    private static final long serialVersionUID = -1479529526911953462L;
    private Long id;
    private String username;
    private String name;
}

Spring Boot自动配置Redis会将相关配置属性绑定到org.springframework.boot.autoconfigure.data.redis.RedisProperties类,更多的配置信息可以参考该类的API文档或源代码,比如配置连接池信息,配置数据库索引等。

Reactive

如果需要基于Reactive编程,则可以添加spring-boot-starter-data-redis-reactive依赖,这样org.springframework.boot.autoconfigure.data.redis.RedisReactiveAutoConfiguration自动配置类将会生效,它会为我们自动创建一个ReactiveRedisTemplate类型的bean。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis-reactive</artifactId>
</dependency>

之后就可以通过ReactiveRedisTemplate基于Reactive进行编程了。下面是一个简单的示例。

@Autowired
private ReactiveRedisTemplate<Object, Object> reactiveRedisTemplate;

public void reactive() {
    ReactiveValueOperations<Object, Object> opsForValue = this.reactiveRedisTemplate.opsForValue();
    User user = new User();
    user.setId(1L);
    user.setUsername("zhangsan");
    user.setName("张三");
    String key = "user::" + user.getId();
    Mono<Boolean> mono = opsForValue.set(key, user);
    if (mono.block()) {
        Mono<Object> mono2 = opsForValue.get(key);
        mono2.blockOptional().ifPresent(System.out::println);
    }
    
    ReactiveListOperations<Object, Object> opsForList = this.reactiveRedisTemplate.opsForList();
    String listKey = "list1";
    opsForList.leftPushAll(listKey, "A", "B", "C", "D", "E").subscribe();
    Flux<Object> flux = opsForList.range(listKey, 0, 10);
    flux.subscribe(System.out::println);
}

(注:本文基于Spring Boot 2.0.3所写)

0
0
分享到:
评论

相关推荐

    spring-boot-redis-annotation-demo:spring boot —— redis 缓存注解使用示例项目

    spring boot —— redis 缓存注解使用教程 示例项目地址: 依赖 在pom文件添加如下依赖 &lt;groupId&gt;org.springframework.boot &lt;artifactId&gt;spring-boot-starter-data-redis 配置 在application.yml配置文件添加...

    Aurora后台管理系统,完美整合spring boot+shiro+redis

    项目基础框架采用全新的Java Web开发框架 —— Spring Boot2.0.4,消除了繁杂的XML配置,使得二次开发更为简单;数据访问层采用Spring boot Jpa,可快速高效对数据进行操作,消除了大量传统XML配置SQL的代码,分页...

    springcloud整合lettuce使用redis

    在Spring Cloud框架中整合Lettuce来使用Redis作为缓存或数据库存储,是现代微服务架构中的常见实践。本文将详细讲解如何实现这一过程,并深入探讨相关知识点。 首先,让我们了解下Spring Cloud和Redis的基本概念。...

    Learning Spring Boot 2.0 Second Edition

    除此之外,还会讲解Spring Boot对缓存的支持,如使用Redis进行数据缓存。 微服务架构是Spring Boot常被用于的场景,书中会讨论Spring Cloud的相关组件,如Eureka实现服务发现,Ribbon和Hystrix实现客户端负载均衡和...

    SpringDataRedis的jar包.rar

    4. **Jedis和Lettuce客户端**:Spring Data Redis兼容两种主流的Redis Java客户端——Jedis和Lettuce。用户可以根据性能、功能需求以及社区支持情况选择合适的客户端。 5. **Redis Repositories**:Spring Data的...

    Spring Boot+Redis 分布式锁:模拟抢单.pdf

    在Spring Boot与Redis结合的场景下,分布式锁的应用更是频繁。本次文档将围绕Spring Boot结合Redis实现分布式锁的机制进行详细解读,并通过模拟抢单的场景来展示其实际运用。 首先,了解Redis的分布式锁是如何运作...

    spring-data-redis最新架包

    这个最新的框架版本——"spring-data-redis-2.0.7-RELEASE",旨在提升开发效率,使得在Spring应用程序中集成Redis变得更加便捷。 Spring Data Redis的核心目标是简化Redis操作,提供一套统一的API,覆盖了Redis的...

    深度剖析Spring Boot自动装配机制实现原理(csdn)————程序.pdf

    以`spring-boot-starter-data-redis`为例,当我们添加了这个依赖,并在配置文件中指定了Redis的相关设置,Spring Boot就会自动识别出`RedisTemplate`需要的bean,并将其注入到Spring容器中。这是因为`spring-boot-...

    基于springboot下对mysql,mongodb,redis支持ipv6的改造(csdn)————程序.pdf

    基于springboot下对mysql,mongodb,redis支持ipv6的改造(csdn)————程序

    myredis-spring-boot-starter.zip

    总的来说,myredis-spring-boot-starter作为Spring Boot生态的一部分,它通过自动配置和封装,使得在Spring Boot应用中集成和使用Redis变得轻而易举。对于需要使用Redis的项目来说,这是一个非常有价值的工具,它...

    Spring-boot web项目实例

    Spring Boot是由Pivotal团队提供的一个开源框架,其目的是简化Spring应用的初始搭建以及开发过程,它集成了大量常用的第三方库配置,如Redis、MyBatis、JPA等,使得开发者能够快速地创建一个独立的、生产级别的基于...

    JavaEE开发的颠覆者SpringBoot实战[完整版].part3

    第10 章 Spring Boot 开发部署与测试 407 10.1 开发的热部署 407 10.1.1 模板热部署 407 10.1.2 Spring Loaded 407 10.1.3 JRebel 409 10.1.4 spring-boot-devtools 413 10.2 常规部署 413 10.2.1 jar 形式 413 ...

    vue+spring boot+maven+SQLSERVER+REDIS+MINIO+JENKINS+dockers生产调度

    这个项目——"vue+spring boot+maven+SQLSERVER+REDIS+MINIO+JENKINS+dockers生产调度"——是一个综合性的解决方案,旨在实现高效、自动化的工作流管理。下面我们将详细探讨每个组件的关键作用及其相互间的协同工作...

    Spring Boot 视频

    此外,我们还将关注Spring Boot集成其他技术的方式,如数据访问(JDBC、MyBatis、Hibernate)、Web开发(Spring MVC)、缓存(Redis、 EhCache)等。Spring Boot提供了便捷的 Starter 包,只需要引入相应的Maven或...

    SpringBoot系列——防重放与操作幂等.doc

    6. Spring Boot 的 Redis 依赖:使用 Spring Boot 的 Redis 依赖来实现 Redis 的操作。 7. MyBatis Plus 的依赖:使用 MyBatis Plus 的依赖来实现数据库的操作。 8. 数据库的唯一主键:使用数据库的唯一主键来防止...

    springboot搭建

    本教程将详细介绍如何使用 Spring Boot 搭建一个包含 Redis 缓存和 MyBatis 数据持久层的简单应用。 ### 一、Spring Boot 概述 Spring Boot 是由 Pivotal 团队提供的全新框架,旨在简化 Spring 应用的初始搭建以及...

    redis实现全局锁 Redisson的Spring Boot核心 RedissonLock.zip

    redis实现全局锁 Redisson的Spring Boot核心 RedissonLockRedisson实现分布式锁有关Redisson实现环球锁前面写了三篇博客该项目作为项目落地的铺垫。1、Redisson实现全局锁(1)---原理2、Redisson实现全球锁(2)——...

    基于SpringBoot的仿牛客论坛源码.zip

    Spring Boot Spring、Spring MVC、MyBatis Redis、Kafka、Elasticsearch Spring Security、Spring Actuator 开发环境 构建工具:Apache Maven 集成开发工具:IntelliJ IDEA 数据库:MySQL、Redis 应用服务器:Apache...

    SpringBoot+Mybatis整合完整源码

    - **创建 Mybatis 配置类**:如果使用 Spring Boot 的自动配置,通常无需额外配置 Mybatis,但如果需要自定义配置,可以创建一个配置类,并使用 `@Configuration` 和 `@MapperScan` 注解。 - **Mapper 接口与 XML ...

Global site tag (gtag.js) - Google Analytics