惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

美团技术团队
D
DataBreaches.Net
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
D
Docker
N
Netflix TechBlog - Medium
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
C
Check Point Blog
腾讯CDC
Stack Overflow Blog
Stack Overflow Blog
V
Visual Studio Blog
IT之家
IT之家
月光博客
月光博客
U
Unit 42
K
Kaspersky official blog
T
Threatpost
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
GbyAI
GbyAI
P
Proofpoint News Feed
Last Week in AI
Last Week in AI
云风的 BLOG
云风的 BLOG
酷 壳 – CoolShell
酷 壳 – CoolShell
I
InfoQ
Engineering at Meta
Engineering at Meta
Recorded Future
Recorded Future
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
Security @ Cisco Blogs
MyScale Blog
MyScale Blog
大猫的无限游戏
大猫的无限游戏
Security Archives - TechRepublic
Security Archives - TechRepublic
Webroot Blog
Webroot Blog
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Hacker News - Newest:
Hacker News - Newest: "LLM"
S
Schneier on Security
S
Secure Thoughts
The Register - Security
The Register - Security
B
Blog RSS Feed
The Last Watchdog
The Last Watchdog
P
Palo Alto Networks Blog
爱范儿
爱范儿
B
Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
N
News and Events Feed by Topic
阮一峰的网络日志
阮一峰的网络日志
L
LINUX DO - 热门话题
C
Cisco Blogs
Spread Privacy
Spread Privacy
F
Full Disclosure
博客园 - 聂微东
T
The Blog of Author Tim Ferriss

博客园 - Zhongkeruanjian

xxzxz 第三方 Zhongkeruanjian - 博客园 使用状态机工作流 懂得Windows WorkFlow Foundation 使用Windows WorkFlow Foundation Windows Workflow Foundation能带来什么 Windows Workflow Foundation简述 Windows Workflow Foundation简介 我所理解的需求捕获与需求分析 Sql Server 2005恢复脚本 深圳金谷软件招聘DOTNET软件研发工程师(深圳地区) qww 12121 c#中的有用的方法 翻译:在我们使用的NET FRAMEWORK类库中发现设计模式(3) 翻译:在我们使用的NET FRAMEWORK类库中发现设计模式(2) 翻译:在我们使用的NET FRAMEWORK类库中发现设计模式(1) Microsoft Enterprise Library---解读Logging之开篇
Microsoft Enterprise Library---解读Cache之设计与分析
Zhongkeruanjian · 2005-08-07 · via 博客园 - Zhongkeruanjian

Microsoft Enterprise Library---解读Cache之设计与分析

Cache应用程序块的作用与设计在MSDN的文章中已经表述得很清楚了,此篇文章旨在将Cache应用程序块更深层次的解剖,并描述其类蓝图及主要流程。

“麻雀虽小,五脏俱全”,对于Cache这种小的应用程序来讲,看上去好像不值得去研究与学习,其实不然,Cache给我很大的启示,它的构架,设计,及编码。

    1 Cache可以划分为以下几个部分:
  ppp.GIF

可以看出,

1.1 ache应用程序块是根据其配置驱动的,而配置是通过Configuration应用程序块读取的。1.2 ache策略调度类包的作用是过期管理和Cache尺寸策略管理,过期管理是定期扫描Cache的所有的CacheItem,根据每个CacheItem自带的过期集合,判断是否过期,如果过期,将调用Cache的过期处理。Cache的尺寸策略管理是在每一个CacheItem添加时触发,判断Cache是否已经达到需要清除的阀值。如超过,将清除配置数目的CacheItem

1.3 Cache后台存储类包用于解决Cache程序块的可用性,即在数据源不可用时,应用程序还可以根据后台存储类的数据继续可用。

1.4 Cache服务类包为与系统的管理者(包括WMI,性能计数器,EventLog)打交道的类。这些类将Cache应用程序的当前运行状态数据发送到系统管理者。以便于使用者通过系统管理者了解当前Cache的运行状况。

2 Cache应用程序块有以下几个特点

2.1 Enterprise Library其他几个应用程序块相同的设计模式。为提高程序块的可灵活性和可扩展性,即用户可通过配置来取得CacheManagerBackingStore,程序块采用了工厂类依靠配置来提供具体的CacheManagerBackingStore,用户可以通过IBackingStore自己扩展BackingStore,你可以将后台存储的数据放在数据库,XML,文件系统。。。。

2.2 采用基于接口编程。接口定义了规范与行为。比如ICacheItemExpiration,一个用于CacheItem如何过期的接口,除了系统自定义的几个过期类外,你可以自己定义过期。

再比如ICacheItemRefreshAction,为CacheItem在过期被移除后履行的接口,便于用户自定义在CacheItem过期后的行为。

2.3 系统性能的监测机制。由于Cache需要占用内存,而内存是有限的,在系统运行前,你无法估计到Cache将占据多大的内存,如果不对Cache的运行状态进行监测,系统往往会在因缓存量的无限制的增加而崩溃。所以Cache提供了完善的监测机制。让你在系统运行时监测到Cache的状态,以便及时调整过期策略与尺寸策略。

3 Cache应用程序块的类图如下:

pppp.GIF