缓存的数据格式是Hash哈希,其实存那种都可以,存进去都是字符串,感觉用k/v不好,如果缓存太多热点数据定义很多k,杂乱的.
Reids依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
配置主机号和redis默认端口号
spring.redis.host=192.168.150.151
spring.redis.port=6379
首先去redis查询,redis没有去数据库查询,查询出来的数据保存到数据库里面
,第二次去查就去redis里面查询
@Autowired
RedisTemplate redisTemplate;
public List<AdItem> getAdsByCid(Long id){
List<AdItem> list2 = null;
HashOperations hash = redisTemplate.opsForHash(); //哈希操作
list2 = (List<AdItem>)hash.get("ads", "big_ad");
if (list2 !=null && list2.size()>0){
System.out.println("----------redis----------");
return list2;
}
List<TbContent> list = tbContentMapper.getAllContentByPage(id,null,null);
System.out.println(">>>>>>>>>>>db>>>>>>>>>>>>>>");
List<AdItem> result = new ArrayList<>(list.size());
for (TbContent tbContent : list) {
AdItem adItem = new AdItem(); //图片
adItem.setSrc(tbContent.getPic());
adItem.setHeight(240);
adItem.setWidth(670);
adItem.setSrcB(tbContent.getPic2());
adItem.setHeightB(240);
adItem.setWidthB(550);
adItem.setAlt(tbContent.getTitleDesc());
adItem.setHref(tbContent.getUrl());
result.add(adItem);
}
hash.put("ads", "big_ad", result);//数据库里面的数据put到Redis里面
return result;
}