Redis使用规范


一.【Key 定义规范】
1. 使用业务或服务名(或数据库名)的英文作为kay的前缀,防止key冲突,用下划线"_"、":"或"."作为间隔,字符包含A-Z,a-z,0-9,提高可读性和可维护性;
2. 禁止使用redis保留字命名kay;
3. 合理控制key的长度,避免使用过长的key或者过简单的key,减少内存消耗并增加易读性;
4. 禁止使用特殊字符:如空格、换行符、单双引号及其他转义字符等;
5. 统一模式,如: object-type:id:field
6. 避免使用超大field的复杂类型对象,超大类型的field需要进行切割;

二.【Value 使用规范】
1. 禁止使用bigkey,防止网卡流量过载和慢查询,如:string类型控制在10KB以内,hash、list、set、zset元素个数不要超过5000;
2. 非字符串的bigkey,避免使用del删除,使用hscan、sscan、zscan方式渐进式删除,可ipeline加速,同时要注意防止bigkey过期时间自动删除问题;
3. 选择合适的数据类型,节省内存,提高性能;

三.【实例及内存使用规范】
1. 一个业务使用一个实例,避免多个业务共用一个实例;
2. 单个实例最大内存使用不能超过实体机的80%;
3. 按业务线合理预估内存使用大小(一般为6个月-24个月);

4. 数据库按服务分开,程序或者zk中必须指定唯一的数据库名(或者库索引名),禁止不同业务或应用使用同一个数据库;

四.【垃圾回收及失效规范】
1. 提前评估数据的生命周期,合理设置数据过期时间和实效策略,如无特殊情况,所有key必须均设置过期时间;
2. 避免使用数据强依赖性,降低因数据失效或逐出是影响业务几率;
2. 避免使用系统自带的自动过期时间机制;
3. 定期手动清理数据空间;
4. 打散过期时间,防止集中过期导致数据不可恢复带来的影响;

五.【客户端使用规范】
1. 客户端连接统一使用redis-cli -h host -p port -a password格式,禁止使用免密登录;
2. 使用带有连接池的数据库,有效控制连接,提高效率;
3. 高并发下客户端添加熔断功能;

六.【命令使用规范】
1. 控制N的数量,有遍历的需求可以使用hscan、sscan、zscan代替;
2. 禁止使用keys、flushall、flushdb等操作;
3. 合理使用select操作;
4. 使用批量操作,提高效率,控制一次性操作元素个数,建议为500;
5. 减少事务的使用(redis不支持事务回滚);

6. 扫描涉及元素数量比较大且设置过期时间的禁止使用scan;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值