C#怎么实现缓存功能 C#如何用MemoryCache和Redis实现数据缓存提升访问速度【架构】

MemoryCache需配置SizeLimit和过期策略,避免内存泄漏;Redis序列化须显式配置JsonSerializerOptions防异常;混合使用时须保证失效同步,防御穿透雪崩需空值缓存+随机key+本地加载锁。MemoryCache 用法和常见误用直接 new MemoryCache(new MemoryCacheOptions()) 就能用,但多数人没配过期策略或大小限制,导致内存悄悄涨满。MemoryCache 是进程内缓存,重启就丢,适合临时、轻量、单机场景必须设置 SizeLimit 和 Size(比如用 SetSize(1)),否则 Remove 不会触发自动淘汰过期时间分两种:AbsoluteExpirationRelativeToNow(绝对时间)和 SlidingExpiration(访问后重置),别混用;SlidingExpiration 在高频读场景下可能让数据永远不淘汰缓存值如果是引用类型,别直接返回 cache.Get<T>("key") 后修改内部字段------Get 返回的是原对象引用,改了会影响后续所有读取Redis 缓存写入时序列化踩坑点用 StackExchange.Redis + System.Text.Json 默认序列化,很容易遇到 null 引用或类型不匹配错误。默认 JsonSerializerOptions 不处理循环引用,实体类有导航属性时直接 Serialize 会抛 System.Text.Json.JsonException缓存 DateTime 时注意时区:.NET 6+ 默认序列化为 ISO 8601 带偏移,但老客户端可能只认 "yyyy-MM-ddTHH:mm:ss" 格式,反序列化失败别把 IDictionary<string, object> 这种弱类型直接塞进 Redis------object 会被序列化成 null 或空对象,读出来是 null 而不是预期字典推荐显式指定 JsonSerializerOptions:new JsonSerializerOptions { PropertyNamingPolicy = JsonNamingPolicy.CamelCase, DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull }MemoryCache 和 Redis 混合使用的典型模式本地缓存 + 分布式缓存组合不是简单"先查本地再查 Redis",关键在失效同步和并发写控制。 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能

相关推荐
輕華1 小时前
LangChain基础入门——从阿里云百炼API到Chain构建
数据库·阿里云·langchain
m0_733565461 小时前
如何在MongoDB中实现按时间跨度的分片路由_时间序列范围分片与冷热节点架构
jvm·数据库·python
woxihuan1234561 小时前
SQL处理大规模分组聚合的内存限制_调整服务器配置
jvm·数据库·python
2401_833033621 小时前
如何用 http 模块创建一个基础的 Web 服务器处理请求
jvm·数据库·python
CLX05052 小时前
golang如何实现群聊功能_golang群聊功能实现策略.txt
jvm·数据库·python
zadyd3 小时前
vLLM Linux 双卡部署大模型服务器指南
linux·人工智能·python·机器学习·vllm
WiChP3 小时前
【V0.1B8】从零开始的2D游戏引擎开发之路
服务器·数据库·mysql
米粒13 小时前
力扣算法刷题 Day 63 Bellman_ford 算法
数据库·算法·leetcode
紫小米9 小时前
后端日志管理
python·fastapi