Redis开发规范
1. 标准化key的格式
- 便于查看、统计、排错。
具体的命名规则可以根据实际情况定义,key名可以使用“系统名:表名:查询字段名:查询字段值:所需要的列名”,如“cif:user:userid:999:username”。
2. 存储的key一定要设置过期时间
- 目前,我们将redis定位成缓存数据库,存放的key必须设有超时时间。
因为若不设置,这些Key会一直占用内存不释放,造成极大的浪费,而且随着时间的推移会导致内存占用越来越大,直到达到服务器内存上限。另外Key的超时长短要根据业务综合评估,而不是越长越好。
3. 冷热数据分离
- 根据业务只将高频热数据存入redis。
其他一些地频冷数据可以存入mysql、es、mongodb等其他数据库中。
另外,redis仅提供非核心业务数据存储,并且只用作cache。
4. 不同业务可以分开存储
- 尽量不要把所有业务放入一个实例。
Redis为单线程处理,独立存储会减少不同业务相互操作的影响,提高请求响应速度;同时也避免单个实例内存数据量膨胀过大,在出现异常情况时可以更快恢复服务。
5. 禁止使用keys、flushall、hmgetall等命令
- 该系列操作效率极低。
redis是单线程,该命令一旦执行会严重阻塞线上其它命令的正常请求,而且在高QPS情况下会直接造成Redis服务崩溃。类似需求可以用scan命令代替。
6. 限制单个value的大小
- 单个value必须小于1M。
7. 大文本数据一定要压缩后存储
- 大文本数据必须先压缩再存储。
大文本数据存入Redis,除了带来极大的内存占用外,在访问量高时,很容易就会将网卡流量占满,进而造成整个服务器上的所有服务不可用,并引发雪崩效应,造成各个系统瘫痪。
8. 不用select功能做多db区分
- 统一使用db0。
不要通过select db频繁切换数据分区,容易影响使用效率。业务量大的话,可以增加新的实例集群,达到分流目的。
9. 需要开启秘钥认证
- 客户端连接时需要使用-a。
开启密码认证,加强redis使用安全。
10. 合理使用不同的数据结构类型
- 按实际也无需求去选择相应的数据结构类型。
String可以用作普通的K-V、计数类;Hash可以用作对象如商品、人员等,包含较多属性的信息;List可以用作消息队列、关注列表等;Set可以用于推荐;Sorted
Set可以用于排行榜等。