MasaFramework -- 缓存入门与规则配置( 三 )


修改缓存Key映射规则修改缓存Key映射规则十分简单 , 我们在配置时更改CacheKeyType为对应的规则即可,但当 CacheKeyType = 3 需要注意,它需要额外提供类型名与别名的对应关系 , 完整例子如下:

  1. 修改appsettings.json, 将CacheKeyType的值改为 3
{"RedisConfig":{"Servers":[{"Host":"localhost","Port":6379}],"DefaultDatabase":3,"ConnectionPoolSize":10,"GlobalCacheOptions": {"CacheKeyType": 3 //CacheKeyType为3时启用别名格式化缓存Key , 可节省缓存Key的键长度}}}
  1. 注册分布式缓存并配置类型名与别名的对应关系
builder.Services.AddDistributedCache(distributedCacheOptions =>{distributedCacheOptions.UseStackExchangeRedisCache();}, typeAliasOptions =>{typeAliasOptions.GetAllTypeAliasFunc = () => new Dictionary<string, string>(){{ "String", "s" }//当类型为String时,格式化后的Key为 s:key};});
通过指定类型与别名的对应关系,从而使得最终形成较短的缓存Key,以达到节省存储空间的目的,缓存Key生成规则可查看
多级缓存示例多级缓存注册方案一. 通过本地配置文件注册
  1. 修改appsettings.json文件,分别配置多级缓存配置以及Redis缓存配置
{// 多级缓存全局配置,非必填"MultilevelCache": {"SubscribeKeyPrefix": "masa",//默认订阅方key前缀,用于拼接channel"SubscribeKeyType": 3, //默认订阅方key的类型,默认ValueTypeFullNameAndKey,用于拼接channel"CacheEntryOptions": {"AbsoluteExpirationRelativeToNow": "00:00:30",//绝对过期时长(距当前时间)"SlidingExpiration": "00:00:50"//滑动过期时长(距当前时间)}},// Redis分布式缓存配置"RedisConfig": {"Servers": [{"Host": "localhost","Port": 6379}],"DefaultDatabase": 3}}
  1. 添加多级缓存并使用分布式Redis缓存
builder.Services.AddMultilevelCache(distributedCacheOptions =>{distributedCacheOptions.UseStackExchangeRedisCache();});方案二. 通过手动指定配置
builder.Services.AddMultilevelCache(distributedCacheOptions =>{distributedCacheOptions.UseStackExchangeRedisCache(RedisConfigurationOptions);});
【MasaFramework -- 缓存入门与规则配置】未配置内存缓存时,默认内存缓存永久有效
除了上述两种方式以外,多级缓存的内存缓存配置也同样支持选项模式,我们可以通过Dcc或者利用 builder.Services.Configure<MultilevelCacheOptions>(builder.Configuration)来支持选项模式
修改缓存Key映射规则源码解读IDistributedCacheClient (分布式缓存客户端)IDistributedCacheClient接口提供以下方法来处理分布式缓存
以下方法会根据全局缓存Key的规则配置以及传入缓存Key的规则配置,检测是否需要格式化缓存Key,对需要格式化Key的操作按照缓存Key格式化规则进行处理,详细查看: