springboot redis 通用读缓存_SpringBoot中整合Redis(缓存篇)

作者:艾神一不小心

来源:juejin.im/post/5b1f35ac6fb9a01e631e24fc

实际开发中缓存处理是必须的,不可能我们每次客户端去请求一次服务器,服务器每次都要去数据库中进行查找,为什么要使用缓存?说到底是为了提高系统的运行速度。将用户频繁访问的内容存放在离用户最近,访问速度最快的地方,提高用户的响应速度,今天先来讲下在springboot中整合redis的详细步骤。

一、安装

redis下载地址:

https://redis.io/download

首先要在本地安装一个redis程序,安装过程十分简单(略过),安装完成后进入到redis文件夹中可以看到如下:

c0213d3d2ca54af4bff73706b266d5b5

点击redis-server.exe开启redis服务,可以看到如下图所示即代表开启redis服务成功:

143014f593a447b2a55830c67ee171da

那么我们可以开启redis客户端进行测试:

eaf1d36d972f4cdd94579232df0ef593

二、整合到springboot

1、在项目中加入redis依赖,pom文件中添加如下:

                    org.springframework.boot            spring-boot-starter-data-redis        

2、在application.yml中添加redis配置:

a98dc0d21f6a4c11a1f00f70298686ef

3、新建RedisConfiguration配置类,继承CachingConfigurerSupport,@EnableCaching开启注解

8f6fbb5a127042e0b8ad972de5a27514
ee3e68e35a114ad0adcdbb0db25acbb7

4、创建自定义的接口来定义需要的redis的功能

/** * K 指以hash结构操作时 键类型 * T 为数据实体 应实现序列化接口,并定义serialVersionUID * RedisTemplate 提供了五种数据结构操作类型 hash / list / set / zset / value * 方法命名格式为 数据操作类型 + 操作 如 hashPut 指以hash结构(也就是map)想key添加键值对  */public interface RedisHelper {    /**     * Hash结构 添加元素 * @param key key * @param hashKey hashKey * @param domain 元素     */    void hashPut(String key, HK hashKey, T domain);    /**     * Hash结构 获取指定key所有键值对 * @param key * @return     */    Map hashFindAll(String key);    /**     * Hash结构 获取单个元素 * @param key * @param hashKey * @return     */    T hashGet(String key, HK hashKey);    void hashRemove(String key, HK hashKey);    /**     * List结构 向尾部(Right)添加元素 * @param key * @param domain * @return     */    Long listPush(String key, T domain);    /**     * List结构 向头部(Left)添加元素 * @param key * @param domain * @return     */    Long listUnshift(String key, T domain);    /**     * List结构 获取所有元素 * @param key * @return     */    List listFindAll(String key);    /**     * List结构 移除并获取数组第一个元素 * @param key * @return     */    T listLPop(String key);    /**     * 对象的实体类     * @param key     * @param domain     * @return     */    void valuePut(String key, T domain);    /**     * 获取对象实体类     * @param key     * @return     */    T getValue(String key);    void remove(String key);    /**     * 设置过期时间 * @param key 键 * @param timeout 时间 * @param timeUnit 时间单位     */    boolean expirse(String key, long timeout, TimeUnit timeUnit);}

下面是创建RedisHelperImpl进行接口的实现

@Service("RedisHelper")public class RedisHelperImpl implements RedisHelper {    // 在构造器中获取redisTemplate实例, key(not hashKey) 默认使用String类型    private RedisTemplate redisTemplate;    // 在构造器中通过redisTemplate的工厂方法实例化操作对象    private HashOperations hashOperations;    private ListOperations listOperations;    private ZSetOperations zSetOperations;    private SetOperations setOperations;    private ValueOperations valueOperations;    // IDEA虽然报错,但是依然可以注入成功, 实例化操作对象后就可以直接调用方法操作Redis数据库    @Autowired    public RedisHelperImpl(RedisTemplate redisTemplate) {        this.redisTemplate = redisTemplate;        this.hashOperations = redisTemplate.opsForHash();        this.listOperations = redisTemplate.opsForList();        this.zSetOperations = redisTemplate.opsForZSet();        this.setOperations = redisTemplate.opsForSet();        this.valueOperations = redisTemplate.opsForValue();    }    @Override    public void hashPut(String key, HK hashKey, T domain) {        hashOperations.put(key, hashKey, domain);    }    @Override    public Map hashFindAll(String key) {        return hashOperations.entries(key);    }    @Override    public T hashGet(String key, HK hashKey) {        return hashOperations.get(key, hashKey);    }    @Override    public void hashRemove(String key, HK hashKey) {        hashOperations.delete(key, hashKey);    }    @Override    public Long listPush(String key, T domain) {        return listOperations.rightPush(key, domain);    }    @Override    public Long listUnshift(String key, T domain) {        return listOperations.leftPush(key, domain);    }    @Override    public List listFindAll(String key) {        if (!redisTemplate.hasKey(key)) {            return null;        }        return listOperations.range(key, 0, listOperations.size(key));    }    @Override    public T listLPop(String key) {        return listOperations.leftPop(key);    }    @Override    public void valuePut(String key, T domain) {        valueOperations.set(key, domain);    }    @Override    public T getValue(String key) {        return valueOperations.get(key);    }    @Override    public void remove(String key) {        redisTemplate.delete(key);    }    @Override    public boolean expirse(String key, long timeout, TimeUnit timeUnit) {        return redisTemplate.expire(key, timeout, timeUnit);    }}

三、测试

编写TestRedis类进行测试

c459912d75c14dea97e77a3eb2276fff
da9589a4b0404ecfb5dfff0c7616ca77

运行TestRedis测试类,结果如下:

f88bbc3212aa44ba960030b36ca268af

注意:如果在RedisConfiguration中不配置redisTemplate(RedisConnectionFactory factory)注解,会造成键、值的一个序列化问题,有兴趣的可以去试一下。

四、项目实战

首先需要在程序的入口处Application中添加@EnableCaching开启缓存的注解

@EnableCaching  //开启缓存@SpringBootApplicationpublic class PoetryApplication {    public static void main(String[] args) {        SpringApplication.run(PoetryApplication.class, args);    }}

上面的redis相关写法是我们自定义设置并获取的,那么我们经常要在访问接口的地方去使用redis进行缓存相关实体对象以及集合等,那么我们怎么实现呢?

比如我现在想在AuthorController中去缓存作者相关信息的缓存数据,该怎么办呢?如下:

003dbaa8265c458db3a655c590eddeee

这里 @Cacheable(value="poemInfo")这个注解的意思就是自动根据方法生成缓存,value就是缓存下来的key。到这里我们就已经把redis整合到了springboot中了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值