SSM之spring注解式缓存redis

简介: SSM之spring注解式缓存redis

在 SSM 架构(Spring + SpringMVC + MyBatis)中,可以通过 Spring 的注解式缓存来实现 Redis 缓存功能。
具体步骤如下:

  1. 添加 Redis 依赖

在 Maven 项目的 pom.xml 文件中添加 Redis 的相关依赖。例如:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
  1. 创建 Redis 配置文件

在 resources 目录下新建一个 spring-redis.xml 文件,并在其中配置 Redis 的相关信息,例如服务器地址、端口号等。

<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
    <!-- 连接池最大连接数 -->
    <property name="maxTotal" value="30"/>
    <!-- 连接池最大空闲连接数 -->
    <property name="maxIdle" value="8"/>
    <!-- 连接池最大等待连接中的时间 -->
    <property name="maxWaitMillis" value="30000"/>
    <!-- 连接超时时间 -->
    <property name="timeout" value="30000"/>
</bean>

<bean id="jedisConnectionFactory"
      class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
    <!-- 设置 redis 地址 -->
    <property name="hostName" value="${spring.redis.host}"/>
    <!-- 设置 redis 端口 -->
    <property name="port" value="${spring.redis.port}"/>
    <!-- 设置数据库索引,默认为0 -->
    <property name="database" value="${spring.redis.database}"/>
    <!-- 使用连接池 -->
    <property name="poolConfig" ref="jedisPoolConfig"/>
</bean>

<bean id="stringRedisTemplate"
      class="org.springframework.data.redis.core.StringRedisTemplate">
    <property name="connectionFactory" ref="jedisConnectionFactory"/>
</bean>
  1. 配置 Redis 缓存

在需要使用 Redis 缓存的地方,可以通过注解来开启缓存功能。例如,在 Service 层中,可以使用 @Cacheable 注解来标记需要缓存的方法,如:

@Service
public class UserService {
   

    @Cacheable(value = "users", key = "#id")
    public User getUser(String id) {
   
        // ...
    }
}

在这里,@Cacheable 注解有两个参数:

  • value 参数指定了缓存的名字,这里我们将其命名为 users。
  • key 参数指定了生成缓存 key 的方式。这里我们将参数 id 作为 key。
  1. 启动 Redis 缓存

最后,在 SpringBoot 的主配置类中,通过 @EnableCaching 注解来启用 Redis 缓存功能,如:

@SpringBootApplication
@EnableCaching
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

这样就可以在 SSM 架构中使用 Spring 注解式缓存来实现 Redis 功能了。

相关文章
|
7月前
|
缓存 监控 Java
SpringBoot @Scheduled 注解详解
使用`@Scheduled`注解实现方法周期性执行,支持固定间隔、延迟或Cron表达式触发,基于Spring Task,适用于日志清理、数据同步等定时任务场景。需启用`@EnableScheduling`,注意线程阻塞与分布式重复问题,推荐结合`@Async`异步处理,提升任务调度效率。
1076 128
|
6月前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。
648 25
|
7月前
|
存储 缓存 NoSQL
Redis专题-实战篇二-商户查询缓存
本文介绍了缓存的基本概念、应用场景及实现方式,涵盖Redis缓存设计、缓存更新策略、缓存穿透问题及其解决方案。重点讲解了缓存空对象与布隆过滤器的使用,并通过代码示例演示了商铺查询的缓存优化实践。
314 1
Redis专题-实战篇二-商户查询缓存
|
6月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
673 3
|
7月前
|
XML Java 数据格式
常用SpringBoot注解汇总与用法说明
这些注解的使用和组合是Spring Boot快速开发和微服务实现的基础,通过它们,可以有效地指导Spring容器进行类发现、自动装配、配置、代理和管理等核心功能。开发者应当根据项目实际需求,运用这些注解来优化代码结构和服务逻辑。
485 12
|
6月前
|
缓存 运维 监控
Redis 7.0 高性能缓存架构设计与优化
🌟蒋星熠Jaxonic,技术宇宙中的星际旅人。深耕Redis 7.0高性能缓存架构,探索函数化编程、多层缓存、集群优化与分片消息系统,用代码在二进制星河中谱写极客诗篇。
1073 3
|
7月前
|
NoSQL Java 调度
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
分布式锁是分布式系统中用于同步多节点访问共享资源的机制,防止并发操作带来的冲突。本文介绍了基于Spring Boot和Redis实现分布式锁的技术方案,涵盖锁的获取与释放、Redis配置、服务调度及多实例运行等内容,通过Docker Compose搭建环境,验证了锁的有效性与互斥特性。
610 0
分布式锁与分布式锁使用 Redis 和 Spring Boot 进行调度锁(不带 ShedLock)
|
7月前
|
传感器 Java 数据库
探索Spring Boot的@Conditional注解的上下文配置
Spring Boot 的 `@Conditional` 注解可根据不同条件动态控制 Bean 的加载,提升应用的灵活性与可配置性。本文深入解析其用法与优势,并结合实例展示如何通过自定义条件类实现环境适配的智能配置。
372 0
探索Spring Boot的@Conditional注解的上下文配置
|
7月前
|
缓存 NoSQL 关系型数据库
Redis缓存和分布式锁
Redis 是一种高性能的键值存储系统,广泛用于缓存、消息队列和内存数据库。其典型应用包括缓解关系型数据库压力,通过缓存热点数据提高查询效率,支持高并发访问。此外,Redis 还可用于实现分布式锁,解决分布式系统中的资源竞争问题。文章还探讨了缓存的更新策略、缓存穿透与雪崩的解决方案,以及 Redlock 算法等关键技术。
|
NoSQL Redis
注解的方式实现redis分布式锁
创建redisLock注解: import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.
1309 0