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

网站到期时间查询电子商务平台信息系统建设

网站到期时间查询,电子商务平台信息系统建设,在软件定义网络架构中管理员,一般做网站是在什么网站找素材缓存使您可以轻松地显着加速应用程序。 Java平台的两种出色的缓存实现是Guava缓存和Ehcache 。 尽管Ehcache功能丰富得多#xff08;例如其Searchable API #xff0c;将缓存持久化到磁盘或溢出到大内存的可能性#xff09;#xff0c;但与Guava相比#xff0c;它也带来了… 缓存使您可以轻松地显着加速应用程序。 Java平台的两种出色的缓存实现是Guava缓存和Ehcache 。 尽管Ehcache功能丰富得多例如其Searchable API 将缓存持久化到磁盘或溢出到大内存的可能性但与Guava相比它也带来了相当大的开销。 在最近的项目中我发现需要将全面的缓存溢出到磁盘上但是与此同时我经常需要使该缓存的特定值无效。 由于Ehcache的Searchable API仅可用于内存中的缓存因此这使我陷入了两难境地。 但是扩展Guava缓存以允许以结构化方式溢出到磁盘非常容易。 这使我既溢出到磁盘又需要必需的失效功能。 在本文中我想展示如何实现这一目标。 我将以实际Guava Cache实例的包装器形式实现此文件持久性缓存FilePersistingCache 。 当然这不是最优雅的解决方案更优雅的方法是使用此行为来实现实际的Guava Cache 但是在大多数情况下我都会这样做。 首先我将定义一个受保护的方法该方法创建前面提到的后备缓存 private LoadingCacheK, V makeCache() {return customCacheBuild().removalListener(new PersistingRemovalListener()).build(new PersistedStateCacheLoader()); }protected CacheBuilderK, V customCacheBuild(CacheBuilderK, V cacheBuilder) {return CacheBuilder.newBuilder(); } 第一种方法将在内部用于构建必要的缓存。 为了实现对缓存的任何自定义要求例如过期策略应该重写第二种方法。 例如这可以是条目或软引用的最大值。 此缓存将与其他任何Guava缓存一样使用。 缓存功能的关键是用于此缓存的RemovalListener和CacheLoader 。 我们将这两个实现定义为FilePersistingCache内部类 private class PersistingRemovalListener implements RemovalListenerK, V {Overridepublic void onRemoval(RemovalNotificationK, V notification) {if (notification.getCause() ! RemovalCause.COLLECTED) {try {persistValue(notification.getKey(), notification.getValue());} catch (IOException e) {LOGGER.error(String.format(Could not persist key-value: %s, %s,notification.getKey(), notification.getValue()), e);}}} }public class PersistedStateCacheLoader extends CacheLoaderK, V {Overridepublic V load(K key) {V value null;try {value findValueOnDisk(key);} catch (Exception e) {LOGGER.error(String.format(Error on finding disk value to key: %s,key), e);}if (value ! null) {return value;} else {return makeValue(key);}} } 从代码中可以明显FilePersistingCache 这些内部类调用了我们尚未定义的FilePersistingCache方法。 这使我们可以通过重写此类来定义自定义序列化行为。 删除侦听器将检查清除缓存条目的原因。 如果RemovalCause被COLLECTED 缓存条目没有由用户手动删除但它已被删除作为高速缓存的驱逐策略的结果。 因此如果用户不希望删除缓存条目我们将仅尝试保留该条目。 CacheLoader将首先尝试从磁盘还原现有值并仅在无法还原该值时创建一个新值。 缺少的方法定义如下 private V findValueOnDisk(K key) throws IOException {if (!isPersist(key)) return null;File persistenceFile makePathToFile(persistenceDirectory, directoryFor(key));(!persistenceFile.exists()) return null;FileInputStream fileInputStream new FileInputStream(persistenceFile);try {FileLock fileLock fileInputStream.getChannel().lock();try {return readPersisted(key, fileInputStream);} finally {fileLock.release();}} finally {fileInputStream.close();} }private void persistValue(K key, V value) throws IOException {if (!isPersist(key)) return;File persistenceFile makePathToFile(persistenceDirectory, directoryFor(key));persistenceFile.createNewFile();FileOutputStream fileOutputStream new FileOutputStream(persistenceFile);try {FileLock fileLock fileOutputStream.getChannel().lock();try {persist(key, value, fileOutputStream);} finally {fileLock.release();}} finally {fileOutputStream.close();} }private File makePathToFile(Nonnull File rootDir, ListString pathSegments) {File persistenceFile rootDir;for (String pathSegment : pathSegments) {persistenceFile new File(persistenceFile, pathSegment);}if (rootDir.equals(persistenceFile) || persistenceFile.isDirectory()) {throw new IllegalArgumentException();}return persistenceFile; }protected abstract ListString directoryFor(K key);protected abstract void persist(K key, V value, OutputStream outputStream)throws IOException;protected abstract V readPersisted(K key, InputStream inputStream)throws IOException;protected abstract boolean isPersist(K key); 所实现的方法在同步文件访问并确保流被适当关闭的同时还要注意对值进行序列化和反序列化。 最后四种方法仍然是抽象的由缓存的用户来实现。 directoryFor(K)方法应为每个密钥标识一个唯一的文件名。 在最简单的情况下密钥的K类的toString方法是以这种方式实现的。 另外我还对persist readPersisted和isPersist方法进行了抽象化处理以实现自定义序列化策略例如使用Kryo 。 在最简单的情况下您将使用内置的Java功能该功能使用ObjectInputStream和ObjectOutputStream 。 对于isPersist 假设仅在需要序列化时才使用此实现则将返回true 。 我添加了此功能以支持混合缓存在混合缓存中您只能将值序列化为某些键。 确保不关闭persist和readPersisted方法中的流因为文件系统锁依赖于要打开的流。 上面的实现将为您关闭流。 最后我添加了一些服务方法来访问缓存。 当然实现Guava的Cache接口将是一个更优雅的解决方案 public V get(K key) {return underlyingCache.getUnchecked(key); }public void put(K key, V value) {underlyingCache.put(key, value); }public void remove(K key) {underlyingCache.invalidate(key); }protected CacheK, V getUnderlyingCache() {return underlyingCache; } 当然可以进一步改善该解决方案。 如果您在并发场景中使用缓存请注意 RemovalListener是除大多数Guava缓存方法以外的异步执行的。 从代码显而易见我添加了文件锁以避免在文件系统上发生读/写冲突。 但是这种异步性确实意味着即使内存中仍然有一个值也很少有机会重新创建值条目。 如果需要避免这种情况请确保在包装器的get方法中调用基础缓存的cleanUp方法。 最后切记在缓存过期时清理文件系统。 最佳地您将使用系统的临时文件夹存储高速缓存条目从而完全避免此问题。 在示例代码中目录由名为persistenceDirectory的实例字段表示该实例字段可以例如在构造函数中初始化。 更新 我对上面描述的内容进行了干净的实现您可以在Git Hub页面和Maven Central上找到这些实现。 如果需要将缓存对象存储在磁盘上请随时使用它。 参考 My Java博客上的JCG合作伙伴 Rafael Winterhalter 扩展了Guava缓存以溢出到磁盘 。 翻译自: https://www.javacodegeeks.com/2013/12/extending-guava-caches-to-overflow-to-disk.html
http://www.yutouwan.com/news/482120/

相关文章:

  • 岳阳网站建设收费标准网页界面ps制作步骤
  • 山西省建设厅官网站成都php网站建设工程师
  • 中山住房和建设局网站建购物网站多少钱
  • 站外推广平台有哪些青岛做网站哪个最好
  • lamp 做网站深圳 公司网站建设
  • 北京网站建设新闻用家用光纤宽带做网站
  • 企业营销型网站建设哪家好4399电脑版网页链接
  • 小白建站软件mvc5 网站开发之学 pdf
  • 手机seo网站推广贸易网站建设公司
  • 第二章 营销型网站建设测验推荐几个安全免费的网站
  • 网站建设及运营工作总结如何高效的完成网站建设步骤
  • 网站型与商城型有什么区别吗网站建设做网站
  • 网站开发项目经理工资客户管理软件免费版哪个好用
  • 如何建立网站教程江门网站建设兼职
  • 衡水专业网站建设公司visual studio怎么创建网页
  • 烟台 o2o平台带动做网站行业最新wordpress教程视频
  • 做网站和做系统哪个难集团网站群
  • 做微网站需要哪种公众号电商网站开发定制
  • 杭州开发网站深圳做棋牌网站建设哪家好
  • 织梦系统做网站flash做的小动画视频网站
  • 怎么样免费建设网站现在免费的外贸平台有哪些
  • 如何建立网站自己做站长开发应用程序的步骤
  • 免费金融网站模板网站营销应该怎么做
  • 医药公司网站模板成都网络公司网站
  • 个人怎么做优惠券网站厦门微信网站
  • 什么是网站建设的三次点击原则做英文网站内容来源
  • 一级a做爰片付费网站用cms做网站的缺点
  • 网站建设的风格团队做网站的收获
  • 大学网站建设技术方案如何免费创建自己的网站平台
  • 北仑网站制作上海网站营销是什么