关于遇到的 redis 的 string 和 hash 问题

2022-05-12 15:38:32 +08:00
 brader

有时候有一批业务,会在 redis 存一些键值对,如: key_uid = xxx (这里的 uid 是用户 id ,不会重复,需要形成缓存的用户还不少)

下面分别是使用 string 和 hash 的存法的一些示例:

String:
SET key_001 xxx
SET key_002 xxx
SET key_003 xxx
...

Hash:
HSET key 001 xxx
HSET key 002 xxx
HSET key 003 xxx
...

其实这两种都是能满足业务需要的,具体我也说不上来哪种做法好,但是我觉得类似这种业务,会产生很多 key 的话,还是用 Hash 好点,起码不会我一打开 redis 软件看到一大堆 key 头晕。 大家知道这种正经应该用哪个吗?

1227 次点击
所在节点    程序员
10 条回复
keaidian
2022-05-12 15:47:20 +08:00
这种情况肯定用 Hash 好啊
brader
2022-05-12 15:50:18 +08:00
@keaidian 看起来也是,就是别人问我为什么的时候答不上来
skidoo34
2022-05-12 15:50:39 +08:00
Hash 里的 Entry 如果太多要记得拆分 否则会有 big key 问题
keaidian
2022-05-12 15:50:48 +08:00
@keaidian 后续维护方便,可以统一设置过期时间,统一删除
brader
2022-05-12 15:53:16 +08:00
@keaidian 这是一个亮点,get
MoYi123
2022-05-12 15:53:20 +08:00
用 string 不能快速 count
用 hash 不能单独设过期时间

不需要考虑 一大堆 key 头晕的问题
看你的需求来
brader
2022-05-12 15:54:36 +08:00
@skidoo34 想请教下,大量的 key 在 Hash 里会有 big key 问题,那同样的大量的 key 在 string 就没有这个问题存在吗
lddsb
2022-05-12 16:41:23 +08:00
string 每个鸡蛋一个篮子
hash 所有鸡蛋在一个篮子
ediron
2022-05-12 16:51:27 +08:00
楼上老哥们都说的很在理
veightz
2022-05-16 19:25:55 +08:00
楼上老哥们都说的很在理;

没有绝对的好坏, 看场景

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/852435

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX