前言
妹子图小程序上线以来,小伙伴们热情高涨,高峰时段达到了1500PV
,当然时间粒度是小时。为了各位小伙伴们能有更好的体验,撸主决定给小程序接入 redis
缓存。
方案
pom.xml
引入:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.5.RELEASE</version>
<relativePath/>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependencies>
application.properties
配置引入:
# Redis
# 数据库索引(默认为0)
spring.redis.database=0
# 服务器地址 变更为自己的
spring.redis.host=127.0.0.1
# 服务器连接端口
spring.redis.port=6379
# 服务器连接密码(默认为空)如果有变更为自己的
spring.redis.password=123456
# 连接池最大连接数(使用负值表示没有限制)
# 建议使用 lettuce 而不是 Jedis
spring.redis.lettuce.pool.max-active=8
# 连接池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.lettuce.pool.max-wait=-1
# 连接池中的最大空闲连接
spring.redis.lettuce.pool.max-idle=8
# 连接池中的最小空闲连接
spring.redis.lettuce.pool.min-idle=0
# 连接超时时间(毫秒)
spring.redis.timeout=30000
RedisConfig
配置:
/**
* redis配置类
*/
@Configuration
@EnableCaching
@AutoConfigureAfter(RedisAutoConfiguration.class)
public class RedisConfig extends CachingConfigurerSupport {
/**
* retemplate相关配置
* @param factory
* @return
*/
@Bean
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
redisTemplate.setConnectionFactory(factory);
return redisTemplate;
}
}
获取妹子图接口,key
默认为传递参数:
@Override
@Cacheable(cacheNames = {"meizi:recommend"})
public Result get(String uuid) {
//业务逻辑
return Result.ok(recommend);
}
更新妹子图缓存接口:
@Override
@Transactional(rollbackFor = Exception.class)
@CacheEvict(cacheNames=""meizi:recommend",key="#recommend.uuid")
public Result update(Recommend recommend) {
return Result.ok("更新成功");
}
小结
这样用户就可以直接访问Redis
获取妹子图,而不再访问宝贵的数据库资源了。