Magicodes.WeiChat——缓存管理

简介: 本框架支持缓存管理,内部机制使用开源库CacheManager。支持全局缓存、租户缓存,默认使用的系统缓存实现,可以在Web.config将其配置为其他缓存类型,比如支持Redis、内存等。 开源库地址:https://github.

本框架支持缓存管理,内部机制使用开源库CacheManager。支持全局缓存、租户缓存,默认使用的系统缓存实现,可以在Web.config将其配置为其他缓存类型,比如支持Redis、内存等。

开源库地址:https://github.com/MichaCo/CacheManager

1.1.1 配置

默认配置如下,见Web.config cacheManager元素内容:

<!--缓存配置-->

<cacheManager xmlns="http://tempuri.org/CacheManagerCfg.xsd">

<managers>

<cache name="defaultCache" updateMode="Up" enableStatistics="true" enablePerformanceCounters="true">

<handle ref="sysCache" name="defaultHandle" expirationMode="Absolute" timeout="3600s"/>

</cache>

</managers>

<cacheHandles>

<handleDef id="sysCache" type="CacheManager.SystemRuntimeCaching.MemoryCacheHandle`1, CacheManager.SystemRuntimeCaching" />

</cacheHandles>

</cacheManager>

相关配置说明请参考:http://cachemanager.net/Documentation/Index/cachemanager_configuration

1.1.2 相关函数介绍:
/// <summary>

/// 获取缓存

/// </summary>

/// <typeparam name="T">值类型</typeparam>

/// <param name="key">key</param>

/// <returns></returns>

public T Get<T>(string key)

/// <summary>

/// 获取缓存

/// </summary>

/// <typeparam name="T">值类型</typeparam>

/// <param name="key">key</param>

/// <param name="tenantKey">租户Key值,如果为NULL则框架会自动获取当前账户的租户Id</param>

/// <returns></returns>

public T GetByTenant<T>(string key, string tenantKey = null)

/// <summary>

/// 添加或更新缓存

/// </summary>

/// <typeparam name="T">值类型</typeparam>

/// <param name="key">key</param>

/// <param name="value"></param>

public void AddOrUpdate<T>(string key, T value)

/// <summary>

/// 添加或更新缓存

/// </summary>

/// <typeparam name="T">值类型</typeparam>

/// <param name="key">key</param>

/// <param name="value"></param>

/// <param name="expire">过期时间</param>

public void AddOrUpdate<T>(string key, T value, TimeSpan expire)

/// <summary>

/// 根据租户缓存

/// </summary>

/// <typeparam name="T"></typeparam>

/// <param name="key"></param>

/// <param name="value"></param>

/// <param name="tenantKey">租户Key值,如果为NULL则框架会自动获取当前账户的租户Id</param>

public void AddOrUpdateByTenant<T>(string key, T value, string tenantKey = null)

/// <summary>

/// 根据租户缓存

/// </summary>

/// <typeparam name="T"></typeparam>

/// <param name="key"></param>

/// <param name="value"></param>

/// <param name="expire"></param>

/// <param name="tenantKey"></param>

public void AddOrUpdateByTenant<T>(string key, T value, TimeSpan expire, string tenantKey = null)

/// <summary>

/// 移除

/// </summary>

/// <param name="key">缓存Key</param>

/// <returns>是否移除成功</returns>

public bool Remove<T>(string key)

/// <summary>

/// 根据租户移除

/// </summary>

/// <param name="key">缓存Key</param>

/// <param name="tenantKey">租户Key值,如果为NULL则框架会自动获取当前账户的租户Id</param>

/// <returns>是否移除成功</returns>

public bool RemoveByTenant<T>(string key, string tenantKey = null)

/// <summary>

/// 清理所有

/// </summary>

/// <typeparam name="T">值类型</typeparam>

public void Clear<T>()

/// <summary>

/// 清理所有

/// </summary>

/// <typeparam name="T">值类型</typeparam>

/// <param name="tenantKey">租户Key值,如果为NULL则框架会自动获取当前账户的租户Id</param>

public void ClearByTenant<T>(string tenantKey = null)
1.1.3 Demo

获取缓存对象:

using Magicodes.WeiChat.Infrastructure.Cache;

var cache =CacheManager.Current;

获取值(全局):

var value = cache.Get<int>("UserSummaryCount");

获取值(按租户)

var value = cache.GetByTenant<int>("UserSummaryCount");

添加或更新值(全局):

cache.AddOrUpdate("UserSummaryCount", value);

cache.AddOrUpdate("UserSummaryCount", value, TimeSpan.FromHours(1));

添加或更新值(按租户):

cache.AddOrUpdateByTenant("UserSummaryCount", value);

cache.AddOrUpdateByTenant("UserSummaryCount", value, TimeSpan.FromHours(1));

目录
相关文章
|
7月前
|
消息中间件 缓存 NoSQL
利用Redis实现高效缓存管理与加速
本文将探讨如何利用Redis作为缓存管理工具,通过深入分析Redis的特性、使用场景和优势,帮助开发人员更好地理解和应用Redis来提升系统性能和响应速度。
|
7月前
|
缓存 NoSQL Apache
Shiro - 缓存管理与CacheManagerAware接口
Shiro - 缓存管理与CacheManagerAware接口
125 0
|
消息中间件 设计模式 存储
高效协作处理缓存清理需求:生产者-消费者模式助力多模块缓存管理
在现代应用系统中,缓存是提高性能和减少数据库负载的重要手段之一。然而,缓存的数据在某些情况下可能会过期或者变得无效,因此需要及时进行清理。在复杂的应用系统中,可能有多个系统、多个模块产生缓存清理需求,而这些系统、模块之间的清理任务需要高效的协作,以避免数据竞争和资源浪费的问题。
128 0
高效协作处理缓存清理需求:生产者-消费者模式助力多模块缓存管理
|
缓存 NoSQL 调度
微服务实践01--微服务管理11--缓存04--实践01--缓存使用
微服务实践01--微服务管理11--缓存04--实践01--缓存使用
192 0
微服务实践01--微服务管理11--缓存04--实践01--缓存使用
|
设计模式 存储 缓存
微服务实践01--微服务管理11--缓存03--典型缓存架构设计
微服务实践01--微服务管理11--缓存03--典型缓存架构设计
435 0
微服务实践01--微服务管理11--缓存03--典型缓存架构设计
|
存储 缓存 NoSQL
微服务实践01--微服务管理11--缓存02--分级缓存设计
微服务实践01--微服务管理11--缓存02--分级缓存设计
342 0
微服务实践01--微服务管理11--缓存02--分级缓存设计
|
存储 缓存 监控
微服务实践01--微服务管理11--缓存01--技术
微服务实践01--微服务管理11--缓存01--技术
265 0
微服务实践01--微服务管理11--缓存01--技术
|
存储 缓存 搜索推荐
微服务实践01--微服务管理11--缓存00--概述
微服务实践01--微服务管理11--缓存00--概述
135 0
|
存储 缓存 网络协议
RH358管理DNS和DNS服务器--使用Unbound配置缓存名称服务器
RH358管理DNS和DNS服务器--使用Unbound配置缓存名称服务器
1049 0
RH358管理DNS和DNS服务器--使用Unbound配置缓存名称服务器