Go语言技术文章
-
从节点默认不执行任何过期逻辑,仅重放主节点发来的DEL等命令;必须设maxmemory-policy为noeviction(或7.0+启用replica-ignore-maxmemoryyes)防止主动淘汰破坏一致性。396 收藏 -
ZREMRANGEBYSCORE默认闭区间,需用“(”语法实现开区间;误删风险高,执行前须用ZRANGEBYSCORE预查;大ZSet范围删除应分批处理,Redis7.0+支持LIMIT,旧版需客户端循环;ZREMRANGEBYRANK与ZREMRANGEBYSCORE语义不同,不可混用。396 收藏 -
RedisStreams用XADD存操作日志最直接,天然按毫秒级时间戳排序,支持XREAD/XRANGE按时间范围查询,需设MAXLEN防爆涨,多服务通过consumergroup共享且互不干扰,持久化依赖AOF配置。395 收藏 -
noeviction是金融级系统唯一可接受的内存策略,它通过写入失败显式暴露容量瓶颈,杜绝后台自动删数据;淘汰策略属兜底补救,非容量规划手段,须配合85%阈值告警、自动化扩容及OOM错误处理闭环。395 收藏 -
RedisString底层使用SDS而非C字符串,具备O(1)长度获取、二进制安全等特性;其内存布局含sdshdr头(因类型不同为4/6字节)与数据,小字符串存在固定开销;扩容采用几何增长策略易造成内存浪费;≤44字节时启用embstr编码以节省内存和指针跳转开销。394 收藏 -
哨兵节点启用密码认证但未提供密码导致SENTINELmaster报NOAUTH错误;需在sentinel.conf中配置sentinelauth-pass,并手动auth;注意端口、master-name一致性及flags等字段含义。393 收藏 -
直接用SETNX易误删锁,因加锁与设过期非原子操作,且释放锁未校验线程标识;正确做法是SET+NX+EX原子加锁并用Lua脚本校验值后删除。393 收藏 -
直接用LPOP或LRANGE处理大列表会阻塞,因其时间复杂度为O(N),在单线程Redis中长时间占用CPU,导致后续请求排队、超时及连接池耗尽。393 收藏 -
HSET查单个字段更快,SET写整条数据更省网络;字段少且固定用HSET,动态多变或需原子替换用SET;LIST队列易丢消息,推荐STREAM;ZSET排行榜慎用浮点score;大SET内存开销大,慎用SMEMBERS。392 收藏 -
HMSET自Redis6.2起被弃用,应统一使用HSET:支持批量写入、返回实际修改数、空值字段会被删除;需注意原子性(单次多字段更新)、客户端传参规范(推荐mapping=)及代理字段数限制。392 收藏 -
本文整理一套 MySQL InnoDB 死锁排查工作流:从应用报错开始,查看 InnoDB 状态,定位锁等待环,统一事务加锁顺序,缩短锁持有时间,并在业务侧加入有限重试保护。392 收藏 -
Host模式下Redis集群初始化失败,因节点默认上报127.0.0.1导致冲突,必须显式配置bind和cluster-announce-ip为宿主机真实IP,并开放客户端端口及对应+10000总线端口。391 收藏 -
数据库 · MySQL | 3星期前 | 执行计划 · MySQL教程 · 慢查询治理 · 索引优化 · 数据库实战 · mysql 执行计划 慢查询 索引优化 MySQL 8 EXPLAIN ANALYZE
从订单慢查询复现出发,讲清 MySQL 8.x EXPLAIN ANALYZE、估算行数与真实行数、loops、Using filesort、复合索引和上线复查。389 收藏 -
从 MySQL Invisible Indexes 入手,讲清如何用不可见索引灰度验证删索引风险,避免直接 DROP INDEX 带来的线上慢查询和回滚成本。388 收藏 -
Redis键空间事件默认关闭,需配置notify-keyspace-events为KEA等组合才生效;事件频道名格式严格、无历史回放、过期事件延迟不可靠、断连事件丢失且无自动续订。386 收藏