1.缘起:
在增量自动获取器章节的缘起部分,我们曾提到增量缓存,本节我们将深入探讨它以及用于管理增量缓存的管理器。我们还是以增量自动获取器章节提到的例子作为基础,并做更进一步的讨论。
OK,现在让我们开始这有趣的旅程。
首先,基于前面例子给出的上下文,我们知道IIncreaseAutoRetriever获取的增量是用于累积当天的已成交订单报表的。“当天已成交报表”就是一个典型的增量缓存,每当有新的增量到来,都会累加到上面。
我们假设今天是2009.07.08,那么我们可以将当前的增量缓存的ID标记为20090708,每隔一分钟都会有新的增量累加到该增量缓存实例中去。直到时钟指向2009.07.09的00:00:00时,表示当前这一天已经结束,此时,将创建一个新的ID为20090709的增量缓存实例来容纳新的增量。而ID为20090708的增量缓存实例将不会再有新的增量进来,所以,其内容也将不再发生变化。此时,我们可以将ID为20090708的增量缓存实例序列化后进行存储。这样做的好处是,当以后任何时候我们需要查询2009.07.08这一天的报表时,可以直接从存储设备加载20090708的增量缓存到内存中并反序列化,然后返回结果,这样就不用再去重新统计这一天的所有已成交的订单了。
所以,当时间进入2009.07.09,那么ID为20090708的增量缓存实例就变成了一个历史缓存,而标记为20090709的新缓存会处理新来的增量。如此,我们可以使用一个管理器将所有的历史缓存和当前正在运行的缓存管理起来。我设计的ESBasic.ObjectManagement.Increasing.Management.RoundCacheManager就是为的这个目的。
Round缓存管理器的形象示意图如下:
2.适用场合:
RoundCacheManager是依赖于IIncreaseAutoRetriever的,所以如果要使用RoundCacheManager,首先必须满足IIncreaseAutoRetriever所需的条件,另外还有RoundCacheManager需要的额外增强的条件。
(1)需要定时从数据源获取新的增量数据。
(2)数据源可能不只一个。
(3)需要支持“轮”(Round)的概念。在Round切换时,需要能够准确识别增量断点。
(4)增量数据有某个字段是递增的。
(5)需要将获取的增量数据放入到正确的增量缓存。
(6)在Round发生切换时,需要产生新的增量缓存来接收新的增量。而历史的增量缓存也需要被管理起来。
(7)被管理的历史缓存在其过期的时候,会自动从管理器中移除。
3.设计思想与实现
在分析RoundCacheManager的源码之前,我们先将其会涉及到的一些重要概念说明一下。
由于增量缓存是基于Round的,比如上面提到的一天为一个Round,所以,在ESBasic中称这样的缓存为Round
Cache,如果是当前正在使用的增量缓存,则称为Round Increasing Cache。
当Round的切换点到来时,当前的Round Increasing Cache就会演变成一个属于历史的Round
Cache。
首先,ESBasic要求Round Cache必须实现IRoundCache泛型接口,IRoundCache接口定义如下:
分享到:
相关推荐
本人将 zhuweisky博主的博客整理成了PDF文件,以便于脱机浏览,没有经过博主的同意就这么做 实在是不好意思^-^ 现将其资料免费下载 以示对博主的尊重 源博客地址:...
.NET设计规范:约定、惯用法与模式,在.net环境下进行开发设计的经典之作,权威指导.
LiteGo:「迷你」的Android异步并发类库LiteGo是一款基于Java语言的「异步并发类库」,它的核心是一枚「迷你」并发器,它可以自由地设置同一时段的最大「并发」数量,等待「排队」线程数量,还可以设置「排队策略」...
新版根据.NET Framework 3.0和3.5的新特性做了全面更新,主要关注的是直接影响框架可编程能力的设计问题。遵守这些规范对于使用.NET Framework创建高质量的应用程序至关重要。 本书提供配套光盘,内含Designing ...
NET应用架构设计原则、模式与实践.pdf NET应用架构设计原则、模式与实践.pdf
灵活易用的工作流组件、数据字典管理组件、在线表单设计组件、丰富的报表统计组件、即时通讯(IM)组件、邮件中心组件、微信开发相关组件、任务调度组件、自动升级组件、多语言模块,各种常用的商业控件,强大的代码...
新版根据.NET Framework 3.0和3.5的新特性做了全面更新,主要关注的是直接影响框架可编程能力的设计问题。遵守这些规范对于使用.NET Framework创建高质量的应用程序至关重要。 本书提供配套光盘,内含Designing ...
自己写的ado.net类库,已实现有关数据库操作的各种方法,子类只需提供数据库连接,即可调用,极大了实现了代码复用.这是我针对实际开发中经常需要重复开发数据库操作而提出的解决方案. 注意,该类实现的是关于sqlserver...
5.7.4 参数数量可变的成员 147 5.7.5 指针参数 150 5.8 小结 152 第6章 为扩展性而设计 153 6.1 扩展机制 153 6.1.1 非密封类 153 6.1.2 保护成员 155 6.1.3 事件与回调函数 156 6.1.4 虚成员 ...
博文地址:http://blog.csdn.net/csnd_ayo/article/details/72457190
这里收集一些著名的 C/C++ 开发库、SDK、类库、可复用类与结构代码 等信息,列举它们的介绍、参考和网站链接,为各位 C/C++ 程序员和爱好者提供检索和查阅类库的方便。 下面收集的 C/C++ 类库介绍整理来源于文章:...
自从.NET推出以来,他已使用.NET帮助很多行业的用户开发了体现其商业理念的软件产品.Xin Chen是.NET和EAI方面的专家,他与Microsoft和Accenture等多家技术领先的公司合作,为它们的客户提供了优秀的解决方案....
有志于做JAVA系统性的技术提升的同学可与我联系,交个朋友哦~ 本人十余年JAVA架构设计经验,擅长JAVA高可用、分布式、高并发系统架构设计。有志于做JAVA系统性的技术提升的同学可与我联系,交个朋友哦~ 本人十余年...
Coalesys PanelBar + R.a.d Treeview +Xml 构建的Asp.net 菜单和权限管理模块 突破屏蔽限制,自己的网站使劲弹新IE窗口 对页面SCROLLING的CSS不能生效原因 .Net 中IE使用WinForm控件的使用心得。 动态加载用户控件的...
此外,还可以创建一个新类库实现软件复用。 • 第十章介绍.NET下的数据库支持,阐述了ADO.NET的基本概念和结构,并通过示例詊细介绍C#下Web Service数据库访问的方法。 • 第十一章将在以前的基础上介绍一个...
这些规范历经.NET框架三个版本的长期开发,凝聚了数千名开发人员的经验和智慧。微软的各开发组正在使用这些规范开发下一代影响世界的软件产品。 第1章 概述 1 1.1 精心设计的框架所具备的品质 2 1.1.1 精心...
机顶盒传输流解复用器中缓存管理器的FPGA实现,王姝慧,徐钊,本文从机顶盒主芯片的一个IP核——传输流解复用器的开发入手,重点讨论了其中缓存管理器的主要功能和设计要求。在合理选择和配置F
有志于做JAVA系统性的技术提升的同学可与我联系,交个朋友哦~ 本人十余年JAVA架构设计经验,擅长JAVA高可用、分布式、高并发系统架构设计。有志于做JAVA系统性的技术提升的同学可与我联系,交个朋友哦~ 本人十余年...
Android应用源码开发Demo,主要用于毕业设计学习。