当前位置: 首页 > news >正文

上海网站建设专业公司14年网站开发经验

上海网站建设专业公司,14年网站开发经验,网址查询入口,网站手机版绑定域名Caffeine 概念缓存手动加载自动加载手动异步加载自动异步加载 驱逐策略基于容量基于时间基于引用 移除显式移除 概念 Caffeine是一个基于Java8开发的提供了近乎最佳命中率的高性能的缓存库。与ConcurrentMap有点相似。最根本的区别是ConcurrentMap将会持有所有加入到缓存当中的… Caffeine 概念缓存手动加载自动加载手动异步加载自动异步加载 驱逐策略基于容量基于时间基于引用 移除显式移除 概念 Caffeine是一个基于Java8开发的提供了近乎最佳命中率的高性能的缓存库。与ConcurrentMap有点相似。最根本的区别是ConcurrentMap将会持有所有加入到缓存当中的元素直到它们被从缓存当中手动移除。Caffeine的缓存Cache 通常会被配置成自动驱逐缓存中元素以限制其内存占用。在某些场景下LoadingCache和AsyncLoadingCache尤为重要。 Caffeine提供了灵活的构造器去创建一个拥有下列特性的缓存 1自动加载元素到缓存当中异步加载的方式也可供选择 2当达到最大容量的时候可以使用基于就近度和频率的算法进行基于容量的驱逐 3将根据缓存中的元素上一次访问或者被修改的时间进行基于过期时间的驱逐 4当向缓存中一个已经过时的元素进行访问的时候将会进行异步刷新 5key将自动被弱引用所封装 6value将自动被弱引用或者软引用所封装 7驱逐(或移除)缓存中的元素时将会进行通知 8写入传播到一个外部数据源当中 9持续计算缓存的访问统计指标 缓存 Caffeine提供了四种缓存添加策略手动加载自动加载手动异步加载和自动异步加载。 手动加载 CacheString, String cache Caffeine.newBuilder().expireAfterWrite(10, TimeUnit.MINUTES).maximumSize(10000).build();// 查找一个缓存元素 没有查找到的时候返回nullString scache.getIfPresent(xiaohei);// 查找缓存如果缓存不存在则生成缓存元素, 如果无法生成则返回nulls cache.get(xiaohei, k - new String(啥也没有));// 添加或者更新一个缓存元素cache.put(xiaohei1, new String());// 移除一个缓存元素cache.invalidate(xiaohei);Cache 接口提供了显式搜索查找、更新和移除缓存元素的能力。 推荐使用cache.get(key, k - value)操作来在缓存中不存在该key对应的缓存元素的时候进行计算生成并直接写入至缓存内而当该key对应的缓存元素存在的时候将会直接返回存在的缓存值。一次 cache.put(key, value) 操作将会直接写入或者更新缓存里的缓存元素在缓存中已经存在的该key对应缓存值都会直接被覆盖。也可以使用Cache.asMap()所暴露出来的ConcurrentMap的方法对缓存进行操作。 自动加载 LoadingCacheString, String cache Caffeine.newBuilder().maximumSize(10000).expireAfterWrite(10, TimeUnit.MINUTES).build(key - new String(啥也没有)); // 查找缓存如果缓存不存在则生成缓存元素, 如果无法生成则返回nullString s cache.get(xiaohei); // 批量查找缓存如果缓存不存在则生成缓存元素MapString, String map cache.getAll(Arrays.asList(new String[]{xiaohei1, xiaohei2}));一个LoadingCache是一个Cache 附加上CacheLoader能力之后的缓存实现。默认情况下在getAll 方法中将会对每个不存在对应缓存的key调用一次CacheLoader.load来生成缓存元素。 手动异步加载 AsyncCacheString, String cache Caffeine.newBuilder().expireAfterWrite(10, TimeUnit.MINUTES).maximumSize(10000).buildAsync();// 查找一个缓存元素 没有查找到的时候返回nullCompletableFutureString graph cache.getIfPresent(xiaohei);// 查找缓存元素如果不存在则异步生成graph cache.get(xiaohei, k - new String(xiaoheissss));// 添加或者更新一个缓存元素cache.put(xiaobai, graph);// 移除一个缓存元素cache.synchronous().invalidate(xiaohei);一个AsyncCache是Cache的一个变体AsyncCache提供了在Executor上生成缓存元素并返回 CompletableFuture的能力。这给出了在当前流行的响应式编程模型中利用缓存的能力。 synchronous()方法给Cache提供了阻塞直到异步缓存生成完毕的能力。也可以使用 AsyncCache.asMap()所暴露出来的ConcurrentMap的方法对缓存进行操作。默认的线程池实现是 ForkJoinPool.commonPool() 也可以通过覆盖并实现 Caffeine.executor(Executor)方法来自定义线程池选择。 自动异步加载 AsyncLoadingCacheString, String cache Caffeine.newBuilder().maximumSize(10000).expireAfterWrite(10, TimeUnit.MINUTES)// 你可以选择: 去异步的封装一段同步操作来生成缓存元素.buildAsync(key - new String(key));// 你也可以选择: 构建一个异步缓存元素操作并返回一个future // .buildAsync((key, executor) - createExpensiveGraphAsync(key, executor));// 查找缓存元素如果其不存在将会异步进行生成CompletableFutureString graph cache.get(xiaohei); // 批量查找缓存元素如果其不存在将会异步进行生成CompletableFutureMapString, String graphs cache.getAll(Arrays.asList(new String[]{xiaohei1, xiaohei2}));一个 AsyncLoadingCache是一个AsyncCache加上AsyncCacheLoader能力的实现。在需要同步的方式去生成缓存元素的时候CacheLoader是合适的选择。而在异步生成缓存的场景下AsyncCacheLoader则是更合适的选择并且它会返回一个 CompletableFuture。默认情况下在getAll 方法中将会对每个不存在对应缓存的key调用一次 AsyncCacheLoader.asyncLoad 来生成缓存元素。 可以通过实现一个 AsyncCacheLoader.asyncLoadAll并在其中为没有在参数中请求的key也生成对应的缓存元素。如果对应某个key生成的缓存元素与包含这个key的一组集合剩余的key所对应的元素一致那么在asyncLoadAll中也可以同时加载剩下的key对应的元素到缓存当中。 驱逐策略 基于容量 Caffeine提供了三种驱逐策略分别是基于容量基于时间和基于引用三种类型。 // 基于缓存内的元素个数进行驱逐 LoadingCacheString, String graphs Caffeine.newBuilder().maximumSize(10000).build(key - new String(key)); // 基于缓存内元素权重进行驱逐 LoadingCacheString, String graphs Caffeine.newBuilder().maximumWeight(10000).weigher((String s, String s1) - s1.length()).build(key - new String(key));基于缓存内的元素个数进行驱逐策略中使用Caffeine.maximumSize(long)。缓存将会尝试通过基于就近度和频率的算法来驱逐掉不会再被使用到的元素。 缓存中的元素可能有不同的内存占用–需要借助Caffeine.weigher(Weigher)方法来界定每个元素的权重并通过 Caffeine.maximumWeight(long)方法来界定缓存中元素的总权重来实现上述的场景。在基于权重驱逐的策略下一个缓存元素的权重计算是在其创建和更新时此后其权重值都是静态存在的在两个元素之间进行权重的比较的时候并不会根据进行相对权重的比较。 基于时间 // 基于固定的过期时间驱逐策略LoadingCacheString, String graphs1 Caffeine.newBuilder().expireAfterAccess(5, TimeUnit.MINUTES).build(key - new String());LoadingCacheString, String graphs2 Caffeine.newBuilder().expireAfterWrite(10, TimeUnit.MINUTES).build(key - new String());// 基于不同的过期驱逐策略LoadingCacheString, String graphs Caffeine.newBuilder().expireAfter(new ExpiryString, String() {Overridepublic long expireAfterCreate(NonNull String s, NonNull String s2, long l) {return 0;}Overridepublic long expireAfterUpdate(NonNull String s, NonNull String s2, long l, NonNegative long l1) {return 0;}Overridepublic long expireAfterRead(NonNull String s, NonNull String s2, long l, NonNegative long l1) {return 0;}}).build(key - new String());expireAfterAccess(long, TimeUnit): 一个元素在上一次读写操作后一段时间之后在指定的时间后没有被再次访问将会被认定为过期项。在当被缓存的元素时被绑定在一个session上时当session因为不活跃而使元素过期的情况下这是理想的选择。 expireAfterWrite(long, TimeUnit): 一个元素将会在其创建或者最近一次被更新之后的一段时间后被认定为过期项。在对被缓存的元素的时效性存在要求的场景下这是理想的选择。 expireAfter(Expiry): 一个元素将会在指定的时间后被认定为过期项。当被缓存的元素过期时间收到外部资源影响的时候这是理想的选择。 基于引用 // 当key和缓存元素都不再存在其他强引用的时候驱逐LoadingCacheString, String graphs1 Caffeine.newBuilder().weakKeys().weakValues().build(key - new String());// 当进行GC的时候进行驱逐LoadingCacheString, String graphs2 Caffeine.newBuilder().softValues().build(key - new String());Caffeine 允许去让GC去帮助清理缓存当中的元素其中key支持弱引用而value则支持弱引用和软引用。AsyncCache不支持软引用和弱引用。 Caffeine.weakKeys()在保存key的时候将会进行弱引用。这允许在GC的过程中当key没有被任何强引用指向的时候去将缓存元素回收。由于GC只依赖于引用相等性。这导致在这个情况下缓存将会通过引用相等()而不是对象相等 equals()去进行key之间的比较。 Caffeine.weakValues()在保存value的时候将会使用弱引用。这允许在GC的过程中当value没有被任何强引用指向的时候去将缓存元素回收。由于GC只依赖于引用相等性。这导致在这个情况下缓存将会通过引用相等()而不是对象相等 equals()去进行value之间的比较。 Caffeine.softValues()在保存value的时候将会使用软引用。为了相应内存的需要在GC过程中被软引用的对象将会被通过LRU算法回收。由于使用软引用可能会影响整体性能我们还是建议通过使用基于缓存容量的驱逐策略代替软引用的使用。同样的使用 softValues() 将会通过引用相等()而不是对象相等equals()去进行value之间的比较。 移除 驱逐缓存元素因为策略被移除 失效缓存元素被手动移除 移除由于驱逐或者失效而最终导致的结果 显式移除 可以手动去让某个缓存元素失效而不是只能等待其因为策略而被驱逐。 // 失效key cache.invalidate(小黑); // 批量失效key cache.invalidateAll(Arrays.asList(new String[]{xiaohei1, xiaohei2})); // 失效所有的key cache.invalidateAll();
http://www.w-s-a.com/news/495484/

相关文章:

  • 南宁广告公司网站建设小程序源码破解
  • 沛县做网站xlec网站建设开发方式包括哪些方面
  • 山西网站建设 哪家好四川城乡和建设厅网站
  • 有瀑布流的网站小型商城网站
  • 百石网怎么做网站二次开发软件
  • 网站域名是什么东西制作网页哪家好
  • 合肥网站建设团队简述网站内容管理流程
  • 网站广告是内容营销吗wordpress增加背景图片
  • 网站建设技术jsp课程设计响应式布局网站开发
  • 东莞网站排名优化seo套路网站怎么做的
  • 我做网站网络建站一般多少钱
  • 如何快速提升网站关键词排名房地产网站开发毕业设计
  • 做网站 提交源码 论坛sem分析是什么意思
  • 网站建设与部署阿里云大学百度付费推广有几种方式
  • 作品集怎么做网站个人简历模板免费下
  • 工业网站素材重庆关键词自动排名
  • 拖拽式网站建设费用微网站怎么做的好名字
  • 长沙电信网站备案谷歌推广怎么做最有效
  • 网站建设与管理总结报告华为开发者联盟
  • 门诊部网站建设天空建筑网站
  • 扬州市城乡建设网站高端品牌鞋子有哪些牌子
  • 杭州网站建设招聘网长沙网络销售公司
  • 网站制作一年多少钱免费做电子章网站
  • 信誉好的营销网站建设徐州市铜山新区建设局网站
  • 建行网站关于我们山西seo和网络推广
  • 1m带宽做网站怎么样深圳网站建设制作开发公司
  • 网站建设 服务内容 费用郴州网站建设公司哪里有
  • 网站关键词重要性育才网站建设
  • 网络安全形势下怎么建设学校网站wordpress最新主题下载
  • 自己建设网站需要什么条件.gs域名做网站怎么样