springboot+redis 实现缓存功能
时间: 2023-09-25 11:09:20 浏览: 196
使用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=<redis服务器IP>
spring.redis.port=<redis服务器端口>
spring.redis.password=<redis密码>
```
3. 创建一个Redis配置类,用于将RedisTemplate注入到Spring容器中:
```
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory lettuceConnectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(lettuceConnectionFactory);
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
return redisTemplate;
}
}
```
4. 编写Cacheable注解,用于对需要缓存的方法进行标注:
```
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Cacheable {
// 缓存key的前缀
String prefix() default "";
// 缓存时间,默认为30分钟
long expireTime() default 1800L;
}
```
5. 编写缓存切面,对被Cacheable注解标注的方法进行缓存:
```
@Aspect
@Component
public class CacheAspect {
@Autowired
private RedisTemplate<String, Object> redisTemplate;
@Around("@annotation(com.example.demo.annotation.Cacheable)")
public Object cache(ProceedingJoinPoint joinPoint) throws Throwable {
// 获取方法参数
Object[] args = joinPoint.getArgs();
// 获取方法名
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
Method method = signature.getMethod();
String methodName = method.getName();
// 获取注解信息
Cacheable cacheable = method.getAnnotation(Cacheable.class);
String prefix = cacheable.prefix();
long expireTime = cacheable.expireTime();
// 构造缓存key
StringBuilder keyBuilder = new StringBuilder();
keyBuilder.append(prefix);
for (Object arg : args) {
keyBuilder.append(":").append(arg);
}
String key = keyBuilder.toString();
// 从缓存中获取数据
Object value = redisTemplate.opsForValue().get(key);
if (value != null) {
return value;
}
// 缓存中不存在则调用方法,将返回值存入缓存
Object result = joinPoint.proceed(args);
redisTemplate.opsForValue().set(key, result, expireTime, TimeUnit.SECONDS);
return result;
}
}
```
6. 在需要进行缓存的方法上加上Cacheable注解,即可实现缓存功能:
```
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserDao userDao;
@Override
@Cacheable(prefix = "user", expireTime = 3600L)
public User getUserById(Integer id) {
return userDao.getUserById(id);
}
}
```
这样,在调用getUserById方法时,如果缓存中已经存在数据,则直接返回缓存中的数据;否则调用方法,将返回值存入缓存,并返回结果。这样可以有效地减少数据库的访问次数,提高系统的性能。
阅读全文