Pipeline需显式调用Exec()才发送,否则命令静默丢失;每条命令结果需通过对应Cmd的Result()/Val()获取并检查cmd.Err();集群下须按slot路由到指定节点执行。直接用 rdb.Pipeline(),但不调 Exec() 就等于没发Pipeline 不是自动触发的魔法,它只是把命令攒在内存里等你拍板。你链了一堆 Set()、Get()、ZAdd(),如果最后没调 pip.Exec(ctx),Redis 根本收不到任何请求------程序也不会报错,数据就静默丢失了。Exec() 返回的是整批命令的聚合错误(比如网络断开),不是单条命令成败的判据每个命令返回的 *redis.Cmd(如 *redis.StringCmd)才是结果载体,得调它的 .Result() 或 .Val() 才能取值别在 Exec() 后就以为万事大吉;必须逐个检查 cmd.Err(),因为部分命令可能语法错、key 不存在或类型不匹配,而 Pipeline 仍会继续执行后续命令批量写用户、预热缓存、更新排行榜,这些场景才值得上 Pipeline单次发 10 条以上独立命令,且彼此无依赖(比如不用 A 命令的返回值决定 B 命令的参数),就是 Pipeline 的甜点区。缓存预热:微服务启动时塞几万条 user:1001、config:prod,用单条 Set() 会卡住启动流程,用 Pipeline 可压到 1--2 次 RTT排行榜批量写入:ZAdd(ctx, "leaderboard", redis.Z{Member: "uid1", Score: 95}) 循环几十次,全塞进一个 Pipeline避免滥用:读 3 条数据、写 2 个字段这种量级,Pipeline 带来的收益远小于代码复杂度;不如老老实实用 MGET/MSET集群环境下不能直接 Pipeline(),得先找节点再操作Redis Cluster 不允许跨 slot 打包命令。你往 Pipeline 里塞 {user:123}:profile 和 {order:456}:meta,哪怕只差一个字符,也可能落在不同 slot,节点直接拒收。必须先算 slot:clusterClient.KeySlot("{user:123}:profile")再查节点:node := clusterClient.NodeForKey(slot) 或遍历 clusterClient.Nodes()最后在该 *redis.Client 上调 node.Pipeline() ------ 此时它退化为单机行为更省事的替代:优先用原生命令,比如批量读用 MGET、批量写用 MSET,它们内部已做 slot 分发,比手撸 Pipeline 更稳超时、错误、大 key ------ 这三个坑最容易被忽略很多人只关注"怎么发",不关心"发崩了怎么办"。Pipeline 的失败模式和单条命令完全不同。 VWO 一个A/B测试工具
相关推荐
辞旧 lekkk17 小时前
【Qt】信号和槽2301_8092047019 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txtzjy2777719 小时前
mysql如何选择合适的索引类型_mysql索引设计实战Aaswk19 小时前
Java Lambda 表达式与流处理笨蛋不要掉眼泪19 小时前
Mysql架构揭秘:update语句的执行流程万邦科技Lafite19 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析秋920 小时前
ruoyi项目更换为mysql9.7.0数据库Andya_net20 小时前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限Cyber4K20 小时前
【Python专项】进阶语法-系统资源监控与数据采集(1)冷小鱼21 小时前
JVM 异常崩溃排查全指南:从 Core Dump 到根因定位