自学内容网 自学内容网

开发指南064-Caffeine里模式搜索

平台兼容Caffeine和Redis两种缓存模式,大型应用使用Redis,小型应用使用Caffeine,最外层使用qlmCacheTools进行封装,例如:

public void put(String key, String value){
    if ("Redis".equals(QLMContants.cacheMode)){
        redisutils.set(key,value);
    }
    else if ("Caffeine".equals(QLMContants.cacheMode)){
        CaffeineUtils.put(key,value);
    }
}

其中cacheMode来自配置文件。基本上所有操作都有对应方法,但是Redis有

public Set<K> keys(K pattern),就是按模式搜索,这个在平台上实际应用有查询在线用户,可惜的是Caffeine自己没有对应方法。这个只能老规则,自己写一个
Set<String> keys = momentaryStore.asMap().keySet();
for (String key : keys) {
    if (key.indexOf(pattern)>=0) {
        // 处理匹配的键
        keys.add(key);
    }
}

其中的momentaryStore:

protected  static  Cache<String, Object> momentaryStore =
        Caffeine.newBuilder()
                .expireAfterWrite(24*60, TimeUnit.MINUTES)
                .maximumSize(200000)
                .build();

原文地址:https://blog.csdn.net/wangbing1125/article/details/142700840

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!