目录

Guava Cache使用需求和场景

需求

场景

缓存设置

缓存的并发级别

缓存的初始容量设置

设置最大存储

缓存清除策略

基于存活时间的清除策略

基于容量的清除策略

基于权重的清除 策略

显式清除

基于引用的清除策略

数据内存加载

Cache

LoadingCache


Guava Cache使用需求和场景

Guava Cache 是Google Fuava中的一个内存缓存模块,用于将数据缓存到JVM内存中。

需求

  • 提供了get、put封装操作,能够集成数据源 ;
  • 线程安全的缓存,与ConcurrentMap相似,但前者增加了更多的元素失效策略,后者只能显示的移除元素;
  • Guava Cache提供了多种基本的缓存回收方式
  • 监控缓存加载/命中情况

场景

通常,Guava缓存适用于以下情况:

  • 愿意花费一些内存来提高速度。
  • 使用场景有时会多次查询key。
  • 缓存将不需要存储超出RAM容量的数据

缓存设置

缓存的并发级别

Guava提供了设置并发级别的API,使得缓存支持并发的写入和读取。与ConcurrentHashMap类似,Guava cache的并发也是通过分离锁实现。在通常情况下,推荐将并发级别设置为服务器cpu核心数。

CacheBuilder.newBuilder()// 设置并发级别为cpu核心数,默认为4.concurrencyLevel(Runtime.getRuntime().availableProcessors()).build();

缓存的初始容量设置

我们在构建缓存时可以为缓存设置一个合理大小初始容量,由于Guava的缓存使用了分离锁的机制,扩容的代价非常昂贵。所以合理的初始容量能够减少缓存容器的扩容次数。

CacheBuilder.newBuilder()// 设置初始容量为100.initialCapacity(100).build();

设置最大存储

Guava Cache可以在构建缓存对象时指定缓存所能够存储的最大记录数量。当Cache中的记录数量达到最大值后再调用put方法向其中添加对象,Guava会先从当前缓存的对象记录中选择一条删除掉,腾出空间后再将新的对象存储到Cache中。

CacheBuilder.newBuilder()// 设置最大容量为1000.maximumSize(1000).build();

缓存清除策略

基于存活时间的清除策略

  • expireAfterWrite 写缓存后多久过期
  • expireAfterAccess 读写缓存后多久过期

存活时间策略可以单独设置或组合配置

基于容量的清除策略

通过CacheBuilder.maximumSize(long)方法可以设置Cache的最大容量数,当缓存数量达到或接近该最大值时,Cache将清除掉那些最近最少使用的缓存

基于权重的清除 策略

使用CacheBuilder.weigher(Weigher)指定一个权重函数,并且用CacheBuilder.maximumWeight(long)指定最大总重。

如每一项缓存所占据的内存空间大小都不一样,可以看作它们有不同的“权重”(weights),作为执行清除策略时优化回收的对象

LoadingCache<Key, Graph> graphs = CacheBuilder.newBuilder().maximumWeight(100000).weigher(new Weigher<Key, Graph>() {public int weigh(Key k, Graph g) {return g.vertices().size();}}).build(new CacheLoader<Key, Graph>() {public Graph load(Key key) { // no checked exceptionreturn createExpensiveGraph(key);}});

显式清除

  • 清除单个key:Cache.invalidate(key)
  • 批量清除key:Cache.invalidateAll(keys)
  • 清除所有缓存项:Cache.invalidateAll()

基于引用的清除策略

在构建Cache实例过程中,通过设置使用弱引用的键、或弱引用的值、或软引用的值,从而使JVM在GC时顺带实现缓存的清除

  • CacheBuilder.weakKeys():使用弱引用存储键。当键没有其它(强或软)引用时,缓存项可以被垃圾回收
  • CacheBuilder.weakValues():使用弱引用存储值。当值没有其它(强或软)引用时,缓存项可以被垃圾回收
  • CacheBuilder.softValues():使用软引用存储值。软引用只有在响应内存需要时,才按照全局最近最少使用的顺序回收。考虑到使用软引用的性能影响,我们通常建议使用更有性能预测性的缓存大小限定

垃圾回收仅依赖==恒等式,使用弱引用键的缓存用而不是equals(),即同一对象引用。

数据内存加载

Cache

显式put操作置入内存

private static Cache<Integer, Integer> numCache = CacheBuilder.newBuilder().expireAfterWrite(5, TimeUnit.MINUTES).build();public static void main(String[] args) throws Exception {System.out.println(numCache.getIfPresent(1));Thread.sleep(1000);System.out.println(numCache.getIfPresent(1));Thread.sleep(1000);numCache.put(1, 5);System.out.println(numCache.getIfPresent(1));// console: null null 5
}

LoadingCache

使用自定义ClassLoader加载数据,置入内存中。从LoadingCache中获取数据时,若数据存在则直接返回;若数据不存在,则根据ClassLoader的load方法加载数据至内存,然后返回该数据.

private static LoadingCache<Integer,Integer> numCache = CacheBuilder.newBuilder().expireAfterWrite(5L, TimeUnit.MINUTES).maximumSize(5000L).build(new CacheLoader<Integer, Integer>() {@Overridepublic Integer load(Integer key) throws Exception {System.out.println("no cache");return key * 5;}});public static void main(String[] args) throws Exception {System.out.println(numCache.get(1));Thread.sleep(1000);System.out.println(numCache.get(1));Thread.sleep(1000);numCache.put(1, 6);System.out.println(numCache.get(1));// console: 5 5 6
}

参考资料:

Google CachesExplained

更多深入参考:[Google Guava] 3-缓存

Google Guava Cache高效本地缓存相关推荐

  1. guava_使用Google Guava Cache进行本地缓存

    guava 很多时候,我们将不得不从数据库或另一个Web服务获取数据或从文件系统加载数据. 在涉及网络呼叫的情况下,将存在固有的网络延迟,网络带宽限制. 解决此问题的方法之一是在应用程序本地拥有一个缓 ...

  2. 使用Google Guava Cache进行本地缓存

    很多时候,我们将不得不从数据库或另一个Web服务获取数据或从文件系统加载数据. 在涉及网络呼叫的情况下,将存在固有的网络等待时间,网络带宽限制. 解决此问题的方法之一是在应用程序本地拥有一个缓存. 如 ...

  3. java guava cache_java使用guava cache实现本地缓存

    cache = CacheBuilder.newBuilder() .recordStats() .maximumSize(5000000) .expireAfterWrite(1, TimeUnit ...

  4. mysql caching_Spring Caching抽象和Google Guava Cache

    mysql caching Spring为缓存昂贵的方法调用提供了强大的现成支持. 这里详细介绍了缓存抽象. 我的目标是使用Spring Guava Cache涵盖Spring现在提供的4.0+版本的 ...

  5. 正则表达式 guava_带有正则表达式模式的Google Guava Cache

    正则表达式 guava 最近我看到了一个关于Google Guava的不错的介绍 ,我们在我们的项目中得出结论,使用它的缓存功能真的很有趣. 让我们看一下regexp Pattern类及其编译功能 . ...

  6. Spring Caching抽象和Google Guava Cache

    Spring为缓存昂贵的方法调用提供了强大的开箱即用支持. 这里详细介绍了缓存抽象. 我的目的是要介绍Spring现在为框架的4.0+版本提供的较新的缓存实现之一-使用Google Guava Cac ...

  7. 带有正则表达式模式的Google Guava Cache

    最近我看到了一个关于Google Guava的精彩演讲 ,我们在我们的项目中得出结论,使用它的缓存功能真的很有趣. 让我们看一下regexp Pattern类及其编译功能 . 在代码中经常可以看到,每 ...

  8. (翻译)Google Guava Cache

    翻译自Google Guava Cache This Post is a continuation of my series on Google Guava, this time covering G ...

  9. Caffeine cache实现本地缓存(简单又清楚)

    Caffeine cache实现本地缓存题 缓存填充策略  手动加载  介绍:  使用方式:  同步加载  介绍:  使用方式:  异步加载  介绍:   注意: 异步和同步使用方式相似, 这里的话主 ...

最新文章

  1. mysql的min函数的使用方法_MySQL中MIN()函数的使用教程
  2. 关于a标签的 href 与 onlick
  3. 嗯?原来if可以调用方法的?
  4. 关于注册登陆时候进行的归档解档--严焕培
  5. C语言之函数指针和函数的首地址
  6. 程序员的职业素养文摘
  7. 调整地面材质_家用浴室柜台面什么材质好?Pvc和大理石选哪个合适?
  8. 【直播回顾】URP中如何写Shader?
  9. 分布式架构中数据一致性常见的几个问题
  10. Linex第三章第四章
  11. 原生JS实现Ajax下载文件
  12. ASP.NET面试题(推荐_有答案)
  13. 一个web项目web.xml的配置中context-param配置作用
  14. 分享6款国内、国外开源PHP轻论坛CMS程序
  15. cocos2dx 3.16 VS+BabeLua lua环境配置与代码调试
  16. 异数OS 织梦师-Xnign(四)-- 挑战100倍速Nginx,脚踩F5硬件负载均衡
  17. 【21.09-21.10】近日Paper Quichthrough汇总
  18. openwrt路由器打印机服务器设置_openwrt路由器打印机服务器设置_TP-Link无线路由器打印机设置指南...
  19. C-获得文件大小并动态申请内存屏幕打印文件内容小程序
  20. 如何删除ctrl+alt+方向键的旋转屏幕功能

热门文章

  1. 具有恒流和恒压的直流控制转换器
  2. Vue 3 桌面应用开发(文末附视频)
  3. 在Android Studio编写代码时,使用MaterialCardView的项目无法正常运行怎么办?简简单单搞定它_莫韵乐与bug的奇妙冒险
  4. 第二篇:MySQL之InnoDB物理存储结构
  5. 领扣中国没有php,全国首例领扣型人工角膜临床试验成功实施
  6. SpringBoot整合Druid连接池
  7. 计算最大曝光时间保证图像不拖影
  8. temp python_temp
  9. utf-8编码转中文
  10. python中文文本分析_Python有趣|中文文本情感分析