Redis缓存图片

缓存的数据格式是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;
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章