更新时间:2022-04-22 GMT+08:00
Proxy集群使用多DB限制
华为云对于实现多DB存在一定的约束,建议针对客户业务进行评估:
- 使用约束:
- swapdb不支持多DB。
- info keyspace不支持多DB展示。
- 需要查询每个DB的key总数,可以使用自定义dbstats命令。命令执行数据节点上会有CPU冲高。
- LUA脚本中不支持多DB。
- RANDOMKEY命令不支持。
- 事务命令中不支持嵌入select命令。
- 不支持在lua脚本中使用publish。
- DB数支持范围为0 ~ 255。
- Redis 3.0 proxy不支持开启多DB。
- 性能约束:
- flushdb命令采用逐个key删除的方式执行,耗时久,慢于开源原生实现,速度与SCAN命令相同(需要客户实际测试)。
- dbsize命令耗时长,禁止在代码中使用。
- 多DB场景下keys命令和scan命令性能会有损失(最多50%)。
- 其他约束:
后端存储会按照一定规则对key进行改写,导出RDB数据中的key不是原始的key,但通过Redis协议访问无影响。
单DB实例开启多DB操作步骤
实例默认不开启多DB,在开启和关闭多DB特性之前需要先清空数据,按照以下操作进行多DB开启。
- 登录分布式缓存服务控制台。
- 连接实例,执行flushall命令清空原有数据。
- 在缓存管理页面,单击缓存实例进入实例详情页面。
- 单击“实例配置 > 参数配置”进入参数配置页面。
- 单击multi-db参数后的修改,将参数运行值修改为“yes”。
- 单击“保存”,在修改参数配置弹框中单击“是”开启多DB完成。
父主题: Redis使用
Redis使用所有常见问题
- 什么是预留内存,如何配置预留内存?
- Redis实例CPU使用率达到100%的原因
- Redis实例能否修改VPC和子网?
- Redis 4.0/5.0/6.0实例为什么不支持安全组?
- Redis实例支持的单个Key和Value数据大小是否有限制?
- Redis集群可以读取每个节点的IP地址吗?
- 创建的缓存实例为什么可使用内存比实例规格少一些?
- Redis实例是否支持读写分离?
- Redis实例是否支持多DB方式?
- Redis集群实例是否支持原生集群?
- 什么是哨兵?
- Redis实例是否支持哨兵模式?
- Redis默认的数据逐出策略是什么?
- 使用redis_exporter出错怎么办?
- Redis的安全加固方面有哪些建议?
- Redis 3.0 Proxy集群不支持redisson分布式锁的原因
- 实例是否支持自定义或修改端口?
- 实例是否支持修改访问地址?
- 按需实例转包周期失败是什么原因?
- 按需实例转包周期需要停服么?
- 实例无法删除是什么原因?
- DCS实例是否支持跨可用区部署?
- 集群实例启动时间过长是什么原因?
- 客户使用Redis版本和DCS Redis版本不同是否存在兼容问题?
- DCS Redis有没有后台管理软件?
- Redis实例经常内存满了但是key不多的原因
- DCS缓存实例的数据被删除之后,能否找回?
- Redis实例是否支持SSL连接?
- 如何修改Redis 3.0实例的SSL开关?
- 为什么实例实际可用内存比申请规格小而且已使用内存不为0?
- 如何估算Redis内存占用量
- Cluster集群实例容量和性能未达到瓶颈,但某个分片容量或性能已过载是什么原因?
- DCS是否支持外部扩展模块、插件或者Module?
- Redis key丢失是什么原因
- 访问Redis报OOM错误提示
- 不同编程语言如何使用Cluster集群客户端
- 使用Cluster的Redis集群时建议配置合理的超时时间
- 读取redis数据报超时错误
- Proxy集群使用多DB限制
- 实例是否支持变更可用区
- hashtag的原理、规则及用法示例
- 重启实例后缓存数据会保留吗?
- 如何购买多DB的Proxy集群实例?
more
