Spring boot2.7整合jetcache方法缓存

前面的文章 我们讲了 spring boot 整合 jetcache 做基本字符串数据缓存

但是 我这里有个这样的逻辑

我的 domain 包下 有一个 book 属性类

里面就 id 和 name 属性

设置了 对应的 set get函数

和一个整体的构造函数

java 复制代码
package com.example.javadom.domain;

public class book {
    private int id;
    private String name;

    public void setId(int id) {
        this.id = id;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getId() {
        return id;
    }

    public String getName() {
        return name;
    }

    public book(int id,String name) {
        this.id = id;
        this.name = name;
    }
}

然后 我们接口类直接 new 一个对象 然后 返回回去

我们访问接口

返回正常

那么 我们这个数据 如何用 jetcache缓存呢?

那么 我们就来说说方法缓存

application 配置文件中 我们远程和本地的配置 都给它留着 免得出问题

然后 打开 redis

然后 我们在启动类上 在加一个注解

java 复制代码
@EnableCreateCacheAnnotation
@EnableMethodCache(basePackages="包名")

EnableMethodCache 代表开启方法缓存

因为 它也是索引注解 所以 必须和 EnableCreateCacheAnnotation 配合使用

EnableMethodCache的basePackages设置包名 或者是 定义范围 一定要包含到我们使用方法缓存的目录

这里 我直接给启动类的目录了

这样 我们所有的项目内容 都会被覆盖到

启动类加上 后 方法就可以用了

然后 我们接口代码修改如下图

@Cached 表示 要用缓存处理这个方法 缓存名 叫name key的话 如果你没有特殊表示可以固定死 如果是根据id查询 可以拿id作为 key 这样 就能存入指定数据 更具key寻找

然后 expire 指定过去时间 来个 3600

如果你想改它的单位 可以写 timeUnit

这个就不多说了

area 的区域 也是可以设的

然后 我们重启项目 访问接口 id 我们后面跟个 1吧

但 控制台上 报了个空指针异常

简单说 就是 来到 application 下面 给 remote 下面的配置 都加上 keyConvertor

然后 又会报一个序列化的错误

这个错误 我之前的文章 Exception in thread "main" java.io.NotSerializableException: 就有讲过

让属性类 book 实现 接口 Serializable

然后 在 application中 的 remote下default中加上

javascript 复制代码
valueEncode: java
valueDecode: java

保证 我们数据进出都是java对象

然后 我们重启项目 重新访问接口

这里 就没有任何问题了

我们到 redis 下 keys * 查询

就可以看到对应的key了

相关推荐
掉鱼的猫几秒前
老码农教你:Solon + EasyExcel 导出工具
java·excel
only-qi2 分钟前
Spring Boot 实时广播消息
java·spring boot·后端
Java水解3 分钟前
Java开发实习超级详细八股文
java·后端·面试
带刺的坐椅17 分钟前
老码农教你:Solon + EasyExcel 导出工具
java·excel·solon·easyexcel
迷知悟道28 分钟前
java面向对象的四大核心特征之继承---超详细(保姆级)
java
lixn28 分钟前
深入理解JVM字节码:invokedynamic
java·jvm
数据智能老司机31 分钟前
探索Java 全新的线程模型——结构化并发
java·性能优化·架构
数据智能老司机32 分钟前
探索Java 全新的线程模型——作用域值
java·性能优化·架构
数据智能老司机34 分钟前
探索Java 全新的线程模型——并发模式
java·性能优化·架构
何中应38 分钟前
分布式事务的两种解决方案
java·分布式·后端