直接 new RedisCache 不行,因为 IDistributedCache 是抽象接口且 RedisCache 需由 DI 容器管理以确保连接复用、配置绑定和生命周期控制;手动实例化易致连接泄漏或 ObjectDisposedException。
ASP.NET Core 的 IDistributedCache 是抽象接口,不能直接实例化。你看到的 RedisCache 类虽然存在,但它设计为由 DI 容器管理——手动 new 会绕过连接复用、配置绑定和生命周期控制,极易导致连接泄漏或 ObjectDisposedException。正确路径是通过 AddStackExchangeRedisCache 注册服务,并在需要处注入 IDistributedCache。
在 Program.cs 中配置 Redis 连接字符串和序列化行为。默认使用 System.Text.Json 序列化,但要注意:它不支持 DateTimeKind.Unspecified 的反序列化精度丢失,也不处理循环引用。
Microsoft.Extensions.Caching.StackExchangeRedis NuGet 包"localhost:6379,abortConnect=false,connectTimeout=5000",不要加 redis:// 前缀IDistributedCache 包装器,而非替换内部序列化逻辑var builder = WebApplication.CreateBuilder(args);
builder.Services.AddStackExchangeRedisCache(options =>
{
options.Configuration = builder.Configuration.GetConnectionString("Redis");
options.InstanceName = "myapp:";
});
不用手动序列化。所有 IDistributedCache 实现(包括 Redis)都只接受 byte[],但 SetAsync 等扩展方法已内置 System.Text.Json 序列化。你传入任意可序列化对象,框架自动处理:
DateTimeOffset 或 TimeSpan 的对象默认保留精度Stream、委托),运行时抛 NotSupportedException,不是编译错误
key)必须是合法 Redis key 字符串:不能含空格、控制字符,建议用 my:feature:id 格式await cache.SetAsync("user:123", user, new DistributedCacheEntryOptions
{
AbsoluteExpirationRelativeToNow = TimeSpan.FromMinutes(30),
SlidingExpiration = TimeSpan.FromMinutes(10)
});
没有内置“缓存穿透防护”或“逻辑过期”支持,必须自己编码。常见组合是 GetOrCreateAsync + 异步工厂函数,但要注意:多个并发请求可能同时触发数据库查询(缓存击穿)。
GetAsync 先查缓存,为 null 再执行 DB 查询并 SetAsync
SET key value NX PX 5000)GetOrCreateAsync 工厂里写同步 IO(如 dbContext.Users.Find(id)),必须用 FindAsync
最易忽略的是:Redis 连接中断时,IDistributedCache 默认静默失败(返回 null 或不写入),不会抛异常。务必在关键路径加日志或健康检查验证连接可用性。