更新时间:2024-07-29 GMT+08:00
为了减少大Key和热Key过大,有什么使用建议?
- string类型控制在10KB以内,hash、list、set、zset元素尽量不超过5000个。
- Key的命名前缀为业务缩写,禁止包含特殊字符(比如空格、换行、单双引号以及其他转义字符)。
- Redis事务功能较弱,不建议过多使用。
- 短连接性能差,推荐使用带有连接池的客户端。
- 如果只是用于数据缓存,容忍数据丢失,建议关闭持久化。
- 大Key/热Key的优化方法,请参考下表。
类别 |
方法 |
---|---|
大Key |
进行大Key拆分。 分为以下几种场景:
|
将大Key单独转移到其余存储介质。 无法拆分的大Key建议使用此方法,将不适用Redis能力的数据存至其它存储介质,并在Redis中删除该大Key。
注意:
禁止使用DEL直接删除大Key,可能会造成Redis阻塞,甚至主备倒换。 |
|
热Key |
使用客户端缓存/本地缓存。 该方案需要提前了解业务的热点Key有哪些,设计客户端/本地和远端Redis的两级缓存架构,热点数据优先从本地缓存获取,写入时同时更新,这样能够分担热点数据的大部分读压力。缺点是需要修改客户端架构和代码,改造成本较高。 |
设计熔断/降级机制。 热Key极易造成缓存击穿,高峰期请求都直接透传到后端数据库上,从而导致业务雪崩。因此热Key的优化一定需要设计系统的熔断/降级机制,在发生击穿的场景下进行限流和服务降级,保护系统的可用性。 |
父主题: 大Key/热Key分析