StackExchange.Redis连接字符串错误会导致线程阻塞5秒而非报错,需设connectTimeout/syncTimeout、用ConnectAsync()、全局单例ConnectionMultiplexer、正确判断RedisValue.IsNull、批量操作用MGET、复杂逻辑用Lua、Cluster下禁用SELECT。StackExchange.Redis 连接字符串写错会直接卡死,不是报错默认情况下,ConnectionMultiplexer.Connect() 遇到无法解析的地址、端口不通或 DNS 失败,会阻塞线程长达数秒(默认 5 秒),而不是立刻抛异常。这在 ASP.NET Core 启动或高并发场景下极易引发雪崩。必须显式设置 connectTimeout 和 syncTimeout,例如:"localhost:6379,connectTimeout=2000,syncTimeout=1000"不要用 Connect(),改用异步 ConnectAsync(),并在 await 后检查 IsConnected连接对象是线程安全且应长期复用的------全局单例一个 ConnectionMultiplexer 实例,别每次操作都 new若 Redis 服务不可达,GetDatabase() 仍会成功返回,但第一次调用 StringGet() 等命令时才真正触发连接并超时string 类型读写最常用,但 Get/Set 默认不处理 null 值IDatabase.StringGet() 返回 RedisValue,它不是 string,也不是可空引用类型;当 key 不存在时返回的是 RedisValue.Null,不是 null 或 default(string)。直接强制转 string 会得到空字符串,掩盖了"key 不存在"这个关键状态。正确判断是否存在:用 if (value.IsNull),而不是 if (value == null) 或 string.IsNullOrEmpty(value)存 null 字符串?不行。StringSet("k", null) 会静默失败(返回 false),必须传 RedisValue.Null 才能显式删 key需要序列化对象?别自己拼 JSON 后塞 string ------ 用 HashGetAll() 或封装好的 JsonSerializer 更稳妥,避免 UTF-8 字节 vs 字符串长度歧义批量操作别手写 for 循环,用管道(Pipeline)或 Lua 脚本连续调用 10 次 StringGet() 是 10 次网络往返;用 StringGet(key1), StringGet(key2)... 仍是串行。真正省 RTT 的方式只有两个: arXiv Xplorer ArXiv 语义搜索引擎,帮您快速轻松的查找,保存和下载arXiv文章。
相关推荐
dishugj27 分钟前
HANA 数据库的核心进程架构2301_7820404533 分钟前
CSS Flex布局中如何实现导航栏与Logo的左右分布_利用justify-content- space-between.柒宇.40 分钟前
Redis主从复制集群搭建详解yaoxin52112340 分钟前
400. Java 文件操作基础 - 使用 Buffered Stream I/O 读取文本文件2301_808414381 小时前
MySQL中的函数Mahir081 小时前
MySQL 数据一致性的基石:三大日志( redo log/undo log/binlog)与两阶段提交(Prepare 阶段和Commit 阶段)深度解密用户8356290780511 小时前
使用 Python 自动创建 Excel 折线图x***r1512 小时前
dbeaver-ce-24.1.3-x86_64-setup安装步骤详解(附DBeaver数据库管理与SQL编写教程)一只鹿鹿鹿2 小时前
数据库运维与管理规范(WORD)小白学大数据2 小时前
面向大规模爬取:Python 全站链接爬虫优化(过滤 + 断点续爬)