如题,业务中经常有无限多的需求需要使用 redis ,互相之间往往八竿子打不着。
这种时候传统数据库一般会各个分独立的库或独立的表,感觉分得很开。redis 里一般是怎么处理的呢?用不同前缀的 hmap 区分?感觉不太合适
1 skyone123 2021-11-23 21:53:54 +08:00 同一个项目就前缀,不同项目就分 db 或者用各自的 redis |
![]() | 2 CEBBCAT 2021-11-23 21:54:39 +08:00 via Android 我见过的一个做法是,维护一个前缀中心。比如说把 key 分成三部分,ABC ,AB 用来区分业务,C 是自定的键名。比如用户( 1 )的联络信息( 2 ) '001'+'0002'+'contact' = key(0010002contact) 当然,你也可以根据自己的需求,前后调整 ABC 的位置 |
![]() | 3 liliclinton 2021-11-23 21:54:58 +08:00 容器封装各用各的 |
![]() | 4 adoal 2021-11-23 21:56:23 +08:00 redis 里可以分库,见 select 命令。 |
6 luzihang 2021-11-24 09:38:49 +08:00 使用 key 值前缀来作命名空间 |
![]() | 7 leeyuzhe 2021-11-24 14:46:40 +08:00 就是 key 前缀,现在分库已经不推荐了 |
8 hgyswx1 2021-11-24 15:06:10 +08:00 多起几个服务 |
![]() | 9 retanoj 2021-11-24 18:12:43 +08:00 我们不同业务申请不同的 redis 集群 同一组业务不同功能靠前缀 |
![]() | 10 2TsukasA 2022-01-18 12:45:06 +08:00 在加前缀识别的基础上,redis 存数据的 slot 路由可以由 key 中大括号内的内容指定,如果存在批量操作的可能的话,可以考虑把前缀加在大括号里,保证会被一次批量操作的数据都在同一个 slot 当中 |