V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
awanganddong
V2EX  ›  Redis

redis hash 与 string 适用场景

  •  
  •   awanganddong · 2021-03-02 10:54:47 +08:00 · 2369 次点击
    这是一个创建于 1360 天前的主题,其中的信息可能已经有所发展或是发生改变。

    通常情况下在可以用 hash 的情况下,也可以用 string 。

    这里对 hash 与 string 之间的取舍还不太清楚, 想听听大家的意见。

    10 条回复    2021-03-02 14:49:07 +08:00
    xuanbg
        1
    xuanbg  
       2021-03-02 10:57:38 +08:00
    hash 相当于 map
    awanganddong
        2
    awanganddong  
    OP
       2021-03-02 11:04:32 +08:00
    就比如用户信息,我可以存 string,也可以存 hash 。
    这之间的取舍,还不太清晰。
    rrfeng
        3
    rrfeng  
       2021-03-02 11:18:31 +08:00
    一组数据如果有同时获取的需求,那么就用 hash 。如果没有,hash 和 string 基本一样。因为有 hgetall
    Leviathann
        4
    Leviathann  
       2021-03-02 11:34:00 +08:00 via iPhone
    hash 里的元素好像不能设置 ttl
    jiurenmeng
        5
    jiurenmeng  
       2021-03-02 11:38:49 +08:00
    hash 可以设置键里面的一个值或多个值单独更新,string 更新的是整个,数据结构也不一样
    monsterxx03
        6
    monsterxx03  
       2021-03-02 12:02:22 +08:00
    就用户信息这个 case, 不需要 ttl.
    如果内存占用问不是问题, 建议用 string.
    减少内存是你的头号问题, 考虑用 hash, key 的 overhead 更少.
    hash 问题是如果以后迁移到 redis cluster, 所有 key 会在一个 slot 里, 分布不均匀
    awanganddong
        7
    awanganddong  
    OP
       2021-03-02 12:38:37 +08:00 via Android
    比如 hash 保存用户信息,以前帖子有提示容易做成热 key 和大 value 。这个大 value 指的是 hash 里边所有的值呢,还是单纯的 key field
    Edward4074
        8
    Edward4074  
       2021-03-02 14:13:57 +08:00
    场景 1,实体转化为 hash 存储,优点是可以对某个字段进行更新、原子加等才做
    caola
        9
    caola  
       2021-03-02 14:18:04 +08:00
    hash 有 zipList 会比 string 占用更少的内存
    Edward4074
        10
    Edward4074  
       2021-03-02 14:49:07 +08:00
    场景 1,实体转化为 hash 存储,优点是可以对某个字段进行更新、原子加等操作
    场景 2,针对某个信息存储多个维度值。比如某个帖子,用户是否已点赞,则 field=userId,value=bool
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2806 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 00:31 · PVG 08:31 · LAX 16:31 · JFK 19:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.