0

0

c# 如何用IDistributedCache和Redis实现分布式缓存

煙雲

煙雲

发布时间:2025-12-31 08:04:05

|

506人浏览过

|

来源于php中文网

原创

直接 new RedisCache 不行,因为 IDistributedCache 是抽象接口且 RedisCache 需由 DI 容器管理以确保连接复用、配置绑定和生命周期控制;手动实例化易致连接泄漏或 ObjectDisposedException。

c# 如何用idistributedcache和redis实现分布式缓存

为什么直接 new RedisCache 不行

ASP.NET Core 的 IDistributedCache 是抽象接口,不能直接实例化。你看到的 RedisCache 类虽然存在,但它设计为由 DI 容器管理——手动 new 会绕过连接复用、配置绑定和生命周期控制,极易导致连接泄漏或 ObjectDisposedException。正确路径是通过 AddStackExchangeRedisCache 注册服务,并在需要处注入 IDistributedCache

如何注册 Redis 分布式缓存(.NET 6+)

Program.cs 中配置 Redis 连接字符串和序列化行为。默认使用 System.Text.Json 序列化,但要注意:它不支持 DateTimeKind.Unspecified 的反序列化精度丢失,也不处理循环引用。

  • 确保已安装 Microsoft.Extensions.Caching.StackExchangeRedis NuGet 包
  • 连接字符串格式为 "localhost:6379,abortConnect=false,connectTimeout=5000",不要加 redis:// 前缀
  • 若需自定义序列化(如兼容旧 Newtonsoft.Json 数据),必须实现 IDistributedCache 包装器,而非替换内部序列化逻辑
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddStackExchangeRedisCache(options =>
{
    options.Configuration = builder.Configuration.GetConnectionString("Redis");
    options.InstanceName = "myapp:";
});

IDistributedCache.SetAsync 存对象要先序列化吗

不用手动序列化。所有 IDistributedCache 实现(包括 Redis)都只接受 byte[],但 SetAsync 等扩展方法已内置 System.Text.Json 序列化。你传入任意可序列化对象,框架自动处理:

B2S商城系统
B2S商城系统

B2S商城系统B2S商城系统是由佳弗网络工作室凭借专业的技术、丰富的电子商务经验在第一时刻为最流行的分享式购物(或体验式购物)推出的开源程序。开发采用PHP+MYSQL数据库,独立编译模板、代码简洁、自由修改、安全高效、数据缓存等技术的应用,使其能在大浏览量的环境下快速稳定运行,切实节约网站成本,提升形象。注意:如果安装后页面打开出现找不到数据库等错误,请删除admin下的runtime文件夹和a

下载
  • 值类型、简单类、record 都能直接存取
  • DateTimeOffsetTimeSpan 的对象默认保留精度
  • 若对象含不可序列化字段(如 Stream、委托),运行时抛 NotSupportedException,不是编译错误
  • 缓存键(key)必须是合法 Redis key 字符串:不能含空格、控制字符,建议用 my:feature:id 格式
await cache.SetAsync("user:123", user, new DistributedCacheEntryOptions
{
    AbsoluteExpirationRelativeToNow = TimeSpan.FromMinutes(30),
    SlidingExpiration = TimeSpan.FromMinutes(10)
});

Redis 缓存失效后查数据库的典型模式

没有内置“缓存穿透防护”或“逻辑过期”支持,必须自己编码。常见组合是 GetOrCreateAsync + 异步工厂函数,但要注意:多个并发请求可能同时触发数据库查询(缓存击穿)。

  • GetAsync 先查缓存,为 null 再执行 DB 查询并 SetAsync
  • 若需防击穿,对 key 加分布式锁(如用 Redis 的 SET key value NX PX 5000
  • 避免在 GetOrCreateAsync 工厂里写同步 IO(如 dbContext.Users.Find(id)),必须用 FindAsync
  • 缓存空结果也要设较短过期时间(如 2 分钟),防止缓存穿透

最易忽略的是:Redis 连接中断时,IDistributedCache 默认静默失败(返回 null 或不写入),不会抛异常。务必在关键路径加日志或健康检查验证连接可用性。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

227

2023.10.07

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

402

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

229

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

433

2024.03.01

桌面文件位置介绍
桌面文件位置介绍

本专题整合了桌面文件相关教程,阅读专题下面的文章了解更多内容。

0

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

Redis+MySQL数据库面试教程
Redis+MySQL数据库面试教程

共72课时 | 6.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号