0

0

c# StackExchange.Redis 异步API的使用和最佳实践

煙雲

煙雲

发布时间:2026-01-31 08:08:31

|

837人浏览过

|

来源于php中文网

原创

StackExchange.Redis异步API须以Async结尾且返回Task/Task,禁用.Result/.Wait();IDatabase不可长期缓存;批量操作优先用StringSetAsync或IBatch;须监听ConnectionFailed事件并调优连接池参数。

c# stackexchange.redis 异步api的使用和最佳实践

异步方法命名和返回类型必须匹配 TaskTask

StackExchange.Redis 的异步 API 全部以 Async 结尾,且返回值是 TaskTask,不是 ValueTask,也不是同步方法的包装。误用 .Result.Wait() 会导致线程阻塞、死锁(尤其在 ASP.NET Core 同步上下文里)。

  • 正确写法:await db.StringGetAsync("key")await conn.GetDatabase().HashGetAllAsync("hash")
  • 错误写法:db.StringGetAsync("key").Result(可能死锁)、db.StringGet("key")(同步调用,浪费连接池资源)
  • 注意:所有 IConnectionMultiplexerIDatabase 的异步方法都遵循此约定,没有例外

IDatabase 实例不能跨请求长期缓存

IDatabase 是轻量级、无状态的“视图”,每次调用 conn.GetDatabase() 都返回新实例,但底层复用同一个连接池。很多人误以为要单例缓存它,其实没必要;更危险的是把它当成线程安全对象长期持有并复用——它本身线程安全,但其行为依赖底层 IConnectionMultiplexer 的生命周期。

  • 推荐做法:在 Web API 中,从 DI 容器获取 IConnectionMultiplexer 单例,每次请求内按需调用 GetDatabase(db: int?)
  • 避免:把 IDatabase 存在静态字段或 Scoped 服务中供多次使用(除非明确控制 db index 和配置)
  • 特别注意:GetDatabase(0)GetDatabase(1) 返回不同逻辑数据库,混用会出数据错乱

批量操作优先用 StringSetAsyncPipeline 而非循环 await

对多个 key 执行独立异步操作时,逐个 await 不仅慢,还放大网络往返开销。StackExchange.Redis 支持原子批量(如 StringSetAsync 接收 KeyValuePair[])和管道(ISubscriberIDatabase.Multiplex 级别的 pipeline),但要注意适用场景。

论论App
论论App

AI文献搜索、学术讨论平台,涵盖了各类学术期刊、学位、会议论文,助力科研。

下载
var pairs = new[]
{
    new KeyValuePair("k1", "v1"),
    new KeyValuePair("k2", "v2")
};
await db.StringSetAsync(pairs, When.Always, CommandFlags.HighPriority);
  • StringSetAsync(pairs[]) 是原子写入,适合同一批 key 的简单 set
  • 复杂混合命令(比如 set + expire + publish)要用 IBatch:调用 db.CreateBatch(),添加多个操作,再 await batch.ExecuteAsync()
  • 别用 Task.WhenAll 包裹多个独立 StringGetAsync —— 默认启用 pipelining,但并发数受 ConnectionMultiplexerConnectTimeoutResponseTimeout 影响,容易触发超时

连接异常处理必须监听 ConnectionFailed 和重连逻辑

StackExchange.Redis 不抛出连接异常到业务层,而是静默重连或进入失败状态。如果只 catch RedisException,会漏掉连接断开、DNS 失败、认证失败等早期问题。

  • 必须订阅:conn.ConnectionFailed 事件,记录日志并触发告警
  • 检查状态:conn.IsConnected 是只读快照,不保证下一毫秒有效;真正可靠的是执行一次 await db.PingAsync() 并捕获异常
  • 重连后,旧的 IDatabase 实例仍可继续用(内部自动重绑定),但若自定义了 CommandMapFeatures,需确保初始化逻辑幂等
  • 常见错误现象:RedisConnectionException: No connection is available...,通常是因为连接池耗尽或未配置 AbortOnConnectFail=false

连接池大小、超时时间、重试策略这些参数没设对,比代码写错更容易导致线上雪崩。别跳过 ConfigurationOptions 的细调。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

483

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

545

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

113

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

200

2025.08.29

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

525

2023.08.10

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

982

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

641

2023.11.14

mongodb和redis哪个读取速度快
mongodb和redis哪个读取速度快

redis 的读取速度比 mongodb 更快。原因包括:1. redis 使用简单的键值存储,而 mongodb 存储 json 格式的数据,需要解析和反序列化。2. redis 使用哈希表快速查找数据,而 mongodb 使用 b-tree 索引。因此,redis 在需要高性能读取操作的应用程序中是一个更好的选择。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

486

2024.04.02

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

33

2026.01.31

热门下载

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

精品课程

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

共6课时 | 0.4万人学习

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

共72课时 | 6.5万人学习

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

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