1. 添加pom依赖
<dependencies>
<!-- redis-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
</dependencies>
2. 添加配置文件application.properties
spring.redis.host=192.168.91.100
spring.redis.port=6379
spring.redis.password=123456
如果需要进行远程调用数据库,需要添加dubbo的配置,此处用的是dubbo实现远程调用,如下:
server.port=8082
dubbo.application.name=ego_portal
##使用zookeeper注册中心暴露服务地址
dubbo.registry.address=zookeeper://192.168.91.100:2181
3、在启动类上添加开启Dubbo和开启缓存的注解@EnableDubbo
@EnableCaching
@SpringBootApplication
@EnableDubbo
@EnableCaching
public class EgoPortalApplication {
public static void main(String[] args) {
SpringApplication.run(EgoPortalApplication.class, args);
}
}
若是数据存储到redis里需要使用json格式,需要添加如下配置类:(特别注意@Configuration注解不能写掉)
@Configuration
public class CacheConfiguration {
//数据存储到redis里使用json格式
@Bean
public CacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
//缓存配置对象
RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig();
redisCacheConfiguration = redisCacheConfiguration.entryTtl(Duration.ofMinutes(30L)) //设置缓存的默认超时时间:30分钟
.disableCachingNullValues() //如果是空值,不缓存
.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer())) //设置key序列化器
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(new GenericJackson2JsonRedisSerializer())); //设置value序列化器
return RedisCacheManager
.builder(RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory))
.cacheDefaults(redisCacheConfiguration).build();
}
}
那么,查询数据的时候第一次会到数据库去进行查询,后面再次访问的时候将会从缓存中读取。