Spring Boot是一個(gè)快速開發(fā)的框架,而Redis是一個(gè)基于內(nèi)存的高性能緩存數(shù)據(jù)庫(kù)。在Spring Boot中,可以使用Spring Boot的自動(dòng)配置來整合Redis來實(shí)現(xiàn)緩存技術(shù)。下面是實(shí)現(xiàn)步驟:
1.添加Redis依賴 在pom.xml中添加Redis依賴:
Copy code<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2.配置Redis連接信息 在application.properties中配置Redis連接信息:
# Redis連接信息
spring.redis.host=localhost
spring.redis.port=6379
spring.redis.password=
spring.redis.database=0
spring.redis.timeout=30000
3.編寫Redis緩存配置類 創(chuàng)建一個(gè)RedisConfig類,用來配置Redis緩存:
@Configuration
@EnableCaching
public class RedisConfig extends CachingConfigurerSupport {
/**
* Redis連接工廠
*/
@Bean
public RedisConnectionFactory redisConnectionFactory() {
JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
jedisConnectionFactory.setHostName("localhost");
jedisConnectionFactory.setPort(6379);
jedisConnectionFactory.setPassword("");
jedisConnectionFactory.setDatabase(0);
return jedisConnectionFactory;
}
/**
* Redis模板
*/
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(redisConnectionFactory);
// 設(shè)置key序列化方式
redisTemplate.setKeySerializer(new StringRedisSerializer());
// 設(shè)置value序列化方式
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
return redisTemplate;
}
/**
* Redis緩存管理器
*/
@Bean
public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
.entryTtl(Duration.ofSeconds(30)); // 設(shè)置緩存時(shí)間
return RedisCacheManager.builder(redisConnectionFactory)
.cacheDefaults(redisCacheConfiguration).build();
}
}
4.使用Redis緩存 在需要緩存的方法上添加@Cacheable注解即可:
@Service
public class UserService {
@Autowired
private UserRepository userRepository;
/**
* 根據(jù)ID查詢用戶
*/
@Cacheable(cacheNames = "userCache", key = "#id")
public User getUserById(Long id) {
return userRepository.findById(id).orElse(null);
}
}
在以上示例中,我們定義了一個(gè)名為userCache的緩存,緩存的key為方法的參數(shù)id,緩存時(shí)間為30秒。當(dāng)?shù)谝淮握{(diào)用getUserById方法時(shí),會(huì)從數(shù)據(jù)庫(kù)中查詢用戶,并將查詢結(jié)果緩存到Redis中。當(dāng)下次調(diào)用getUserById方法時(shí),會(huì)從Redis中讀取緩存的結(jié)果。
這就是使用Spring Boot整合Redis來實(shí)現(xiàn)緩存技術(shù)的基本步驟。