【Caffeine入门】浅谈缓存框架Caffeine

Caffeine是一个基于Java8的高性能缓存框架,号称趋于完美。Caffeine受启发于Guava Cache的API,使用API和Guava是一致的。它借鉴了Guava Cache和ConcurrentLinkedHashMap的设计经验。

在Springboot中使用Caffeine

在工程的pom文件引入caffeine的依赖,如下:

<dependency>
            <groupId>com.github.ben-manes.caffeine</groupId>
            <artifactId>caffeine</artifactId>
            <version>2.6.2</version>
        </dependency>

创建一个抽象类AbstractCaffineCache,该类使用范型来约束缓存的数据类型,并实现了三个方法,put、get、clear。

/**
 * @Author ZhuZiKai
 * @Description
 * @date 2022/3/7 10:44
 */
public abstract class AbstractCaffeineCache<T> {

    protected LoadingCache<String, T> loadingCache;

    abstract LoadingCache<String, T> createLoadingCache();

    public boolean put(String key, T value) {
        if (loadingCache == null) {
            loadingCache = createLoadingCache();
        }
        loadingCache.put(key, value);

        return Boolean.TRUE;
    }

    public T get(String key) {
        if (loadingCache == null) {
            loadingCache = createLoadingCache();
        }
        try {

            return loadingCache.get(key);
        } catch (Exception e) {
            return null;
        }
    }

    public boolean clear(String key) {
        if (loadingCache == null) {
            loadingCache = createLoadingCache();
        }
        loadingCache.invalidate(key);
        return Boolean.TRUE;
    }

}

创建MyCaffeineCache的缓存类,该类缓存类。创建LoadingCache类,该类设置了缓存过期的时间,最大的缓存个数。

/**
 * @Author ZhuZiKai
 * @Description
 * @date 2022/3/7 10:44
 */

public class MyCaffeineCache extends AbstractCaffeineCache {

    /**
     * Caffeine配置说明:
     * initialCapacity=[integer]: 初始的缓存空间大小
     * maximumSize=[long]: 缓存的最大条数
     * maximumWeight=[long]: 缓存的最大权重
     * expireAfterAccess=[duration]: 最后一次写入或访问后经过固定时间过期
     * expireAfterWrite=[duration]: 最后一次写入后经过固定时间过期
     * refreshAfterWrite=[duration]: 创建缓存或者最近一次更新缓存后经过固定的时间间隔,刷新缓存
     * recordStats:开发统计功能
     *
     * @return
     */
    @Override
    LoadingCache createLoadingCache() {
        loadingCache = Caffeine.newBuilder()
                .expireAfterWrite(1000L, TimeUnit.MILLISECONDS)
                .initialCapacity(10)
                .maximumSize(100)
                .recordStats()
                .build((CacheLoader<String, String>) key -> null);
        return loadingCache;
    }
}

将MyCaffeineCache注入到spring ioc中,代码如下:

/**
 * @Author ZhuZiKai
 * @Description
 * @date 2022/3/7 10:45
 */
@Configuration
public class CaffeineCacheConfig {
    @Bean
    public MyCaffeineCache MyCaffeineCache(){
        return new MyCaffeineCache();
    }
}

如何使用。

/**
 * @Author ZhuZiKai
 * @Description
 * @date 2022/1/6 9:45
 */
@Aspect
@Component
@Slf4j
public class IdempotentAspect extends BaseController {

    @Resource
    private MyCaffeineCache cache;

    private static final ThreadLocalUtil threadLocalUtil = new ThreadLocalUtil();

    @Around(value = "@annotation(idempotent)")
    public Object around(ProceedingJoinPoint joinPoint, Idempotent idempotent) throws Throwable {

        UserBO user = getUserBO(request);
        Integer userId = user.getUserId();

        String userRequest = userId + request.getRequestURI();

        threadLocalUtil.setLocalUserRequest(userRequest);

        Object uuid = cache.get(userRequest);
        VerifyUtils.throwWhen(uuid != null, idempotent.value());

        return joinPoint.proceed();

    }

    @AfterReturning(value = "@annotation(idempotent)")
    public void afterReturning(JoinPoint point, Idempotent idempotent) {
        try {
            cache.put(threadLocalUtil.getLocalUserRequest(), UUIDUtil.simpleUUID());
        } finally {
            threadLocalUtil.clearLocalUserRequest();
        }
    }
}

使用本地缓存可以加快页面响应速度,缓存分布式缓存读压力,大量、高并发请求的网站比较适用

Caffeine配置说明:

  • initialCapacity=[integer]: 初始的缓存空间大小
  • maximumSize=[long]: 缓存的最大条数
  • maximumWeight=[long]: 缓存的最大权重
  • expireAfterAccess=[duration]: 最后一次写入或访问后经过固定时间过期
  • expireAfterWrite=[duration]: 最后一次写入后经过固定时间过期
  • refreshAfterWrite=[duration]: 创建缓存或者最近一次更新缓存后经过固定的时间间隔,刷新缓存
  • recordStats:开发统计功能

注意:
expireAfterWrite和expireAfterAccess同时存在时,以expireAfterWrite为准。

<think>好的,用户问的是如何在路由器上安装和配置AList文件列表程序。首先我需要回忆一下AList的相关知识。AList是一个支持多种存储的文件列表程序,可以挂载网盘等,通常通过Docker部署。用户提到的是在路由器上安装,所以需要确认路由器是否支持Docker。 根据引用[1],之前有在ARMv7架构的玩客云主机上安装AList和Aria2的例子,使用的是Docker部署。路由器如果是基于类似架构,并且支持Docker的话,步骤可能类似。但很多普通家用路由器可能没有足够的性能或存储来运行Docker,所以需要用户确认路由器的系统是否支持,比如是否是OpenWrt这类第三方固件。 接下来,我需要整理安装步骤。首先,确保路由器系统兼容,比如OpenWrt,并且安装了Docker。然后通过SSH登录路由器,使用Docker命令拉取AList镜像,创建容器,配置端口和数据目录。之后进入AList的Web界面进行进一步设置,比如添加存储和用户管理。 另外,引用[3]提到有些步骤已有详细教程,可能需要引导用户查看相关链接。用户可能还需要内网穿透,如引用[1]中的Cpolar,来公网访问AList,但用户问题暂时没提到这部分,可能后续会需要。 需要注意检查路由器的资源是否足够,存储空间和内存。如果路由器无法运行Docker,可能需要交叉编译AList的二进制文件,或者寻找适合路由器架构的预编译版本,手动安装。 最后,生成相关问题,帮助用户深入解决可能遇到的问题,比如性能优化、结合Aria2使用,或者内网穿透配置。</think>### 如何在路由器上安装和配置AList文件列表程序? #### 前提条件 1. **路由器系统需支持Docker**:推荐使用OpenWrt等支持容器化部署的固件,并确保路由器存储空间和内存足够运行容器[^1]。 2. **SSH访问权限**:需能通过SSH登录路由器后台。 --- #### 分步操作指南 ##### 1. 安装Docker环境 - 若路由器系统未预装Docker,需通过包管理器手动安装。例如在OpenWrt中: ```bash opkg update opkg install docker docker-compose ``` ##### 2. 拉取AList镜像并启动容器 通过SSH连接路由器后执行: ```bash docker run -d \ --name alist \ -p 5244:5244 \ -v /mnt/sda1/alist:/opt/alist/data \ --restart=always \ xhofe/alist:latest ``` - **参数说明**: - `-p 5244:5244`:将容器内5244端口映射到路由器 - `-v /mnt/sda1/alist:/opt/alist/data`:挂载存储目录(需提前创建`/mnt/sda1/alist`) - `--restart=always`:设置容器自动重启 ##### 3. 获取管理员密码 执行以下命令查看初始密码: ```bash docker exec -it alist ./alist admin random ``` 或查看日志: ```bash docker logs alist | grep password ``` ##### 4. 访问Web界面 浏览器输入 `http://路由器IP:5244`,使用用户名`admin`和上一步获取的密码登录。 ##### 5. 配置存储与功能 - **添加存储**:在Web界面中选择“存储” > “添加”,支持阿里云盘、OneDrive等20+种存储类型。 - **用户管理**:可创建多用户并分配不同存储权限。 - **主题与插件**:支持自定义主题和扩展功能插件。 --- #### 常见问题解决 - **端口冲突**:若5244端口被占用,修改`-p`参数为其他端口(如`-p 8080:5244`)。 - **存储挂载失败**:检查挂载路径权限,执行`chmod -R 777 /mnt/sda1/alist`。 - **性能问题**:若路由器资源不足,可关闭非必要插件或限制容器内存: ```bash docker update --memory 256M alist ``` --- #### 扩展应用(结合引用[1]) 若需公网访问AList,可参考引用[1]通过**Cpolar内网穿透**生成公网地址,或配置DDNS实现固定域名访问。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_Romeo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值