【转】ABP源码分析十三:缓存Cache实现
ABP中有兩種cache的實(shí)現(xiàn)方式:MemoryCache 和 RedisCache. 如下圖,兩者都繼承自ICache接口(準(zhǔn)確說是CacheBase抽象類)。ABP核心模塊封裝了MemoryCache 來實(shí)現(xiàn)ABP中的默認(rèn)緩存功能。 Abp.RedisCache這個模塊封裝RedisCache來實(shí)現(xiàn)緩存(通過StackExchange.Redis這個類庫訪問redis)。
?
?
ICache:緩存的接口。以string類型的key緩存object類型的value.ICache.Get方法有兩個參數(shù):
?key:緩存中一個條目的鍵(字符串類型)。
?工廠:沒有找到指定key的緩存條目時,調(diào)用傳入的action來創(chuàng)建cache。工廠方法應(yīng)該創(chuàng)建并返回實(shí)際的條目。如果給定的key在緩存中找到了,那么不會調(diào)用該action。
ICache接口也有像GetOrDefault,Set,Remove,Clear的方法。同時,這些方法也有異步(async)版本。
?
ITypedCache/TypedCacheWrapper: 支持泛型key和value的緩存接口與實(shí)現(xiàn),其內(nèi)部通過封裝ICache實(shí)例和CacheExtension定義的對ICache的擴(kuò)展方法來是實(shí)現(xiàn)泛型版本的Icache.
另外通過CacheExtension中的方法可以方便的將ICache對象轉(zhuǎn)換為 ITypedCache對象。 ITypeCache是ICache的包裝器,提供類型安全、泛型的cache。為了將ICache轉(zhuǎn)為ITypedCache,我們可以使用AsTyped擴(kuò)展方法.
?
?
CacheExtension: 定義了ICache的擴(kuò)展方法. 最關(guān)鍵的是如下兩個支持泛型的方法:GetOrDefault和GetOrDefaultAsync。如下,內(nèi)部調(diào)用ICache實(shí)例的相應(yīng)方法并通過類型轉(zhuǎn)換。
?
?
AbpCacheNames:定義了四個cache的key常量,這幾個cache是供ABP框架使用的
?
ICacheConfigurator/CacheConfigurator:封裝了cache的name和對該cahce的初始化方法,通過初始化方法可以完成對cache的配置(比如過期時間)。
?
?
ICachingConfiguration/CachingConfiguration:?該接口提供完成cache的配置的方法。具體是通過封裝了一個ICacheConfigurator集合,并調(diào)用其上面的InitAction來配置cache。
?
ICacheManager/CacheManagerBase:?該接口和實(shí)現(xiàn)用于生成,配置以及銷毀ICache實(shí)例。具體是通過ICachingConfiguration對象來初始化cache,?并通過ConcurrentDictionary<string, ICache>來存放和管理cache.
?
ICacheManager.GetCache方法返回一個ICache。第一次請求時會創(chuàng)建緩存,并通過CachingConfiguration中的CacheConfigurator完成對該Cache的配置,以后都是返回相同的緩存對象。因此,我們可以在不同的類(客戶端)中共享具有相同名字的相同緩存。
?
AbpMemoryCache:通過CLR的MemoryCache來實(shí)現(xiàn)Icache.
?
AbpMemoryCacheManager:重寫了CacheManagerBase的CreateCacheImplementation方法,該方法用于創(chuàng)建真實(shí)的Icache對象。?具體到AbpMemoryCacheManager就是創(chuàng)建AbpMemoryCache。
?
AbpRedisCacheManager:重寫了CacheManagerBase的CreateCacheImplementation方法,該方法用于創(chuàng)建真實(shí)的Icache對象。?具體到AbpRedisCacheManager就是創(chuàng)建AbpRedisCache。
IAbpRedisConnectionProvider/AbpRedisConnectionProvider:從web.config中讀取Redis的connectionstring信息,并通過connectionstring生成ConnectionMultiplexer對象。AbpRedisConnectionProvider是一個單例實(shí)現(xiàn),并且將ConnectionMultiplexer對象保存在其本地的Dictionary中,避免反復(fù)創(chuàng)建。
AbpRedisCache:實(shí)現(xiàn)了從Redis數(shù)據(jù)庫讀取數(shù)據(jù)的功能。具體則是通過IAbpRedisConnectionProvider對象來訪問redis數(shù)據(jù)庫。
?
返回ABP源碼分析系列文章目錄
總結(jié)
以上是生活随笔為你收集整理的【转】ABP源码分析十三:缓存Cache实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 入手AMD RX 6000系显卡好机会:
- 下一篇: 免费玩!《守望先锋2》BETA版将于6月