标签设计方案
创始人
2024-05-09 06:44:42

设计目标: 400W用户 200个标签

总涉及标签数据 8亿条数据

1. mysql表结构设计

IDuid身份标签ID状态
1111
2121
3221
4330

采用一对多的存储方式 即一个用户对应多条身份标签

2. mysql分表设计 2000W数据分一个表(不涉及大数据量存储 所以2000W数据为一个表)

分表数量 为40个表

根据用户ID取模分片 保证数据均匀落表(同时保证同一用户的身份信息在同一个表上)(缺点:扩容需要做大数据量数据迁移)

3. nosql存储方式

redis bitmaps存储方式
存储key值设计下面为准

耗费内存预估

  1. 按照400W用户 200个标签来设计的话
    单个标签预计消耗内存0.5M
    对于存储所有的标签的key值 大约100M的空间足以支持

  2. 如果需要单独存储用户下面所有的标签 耗费的内存 :
    单个用户耗费的内存 0.0000248M
    400W用户耗费内存 99.2M左右

{// 所有身份标签ID为1的用户身份标识"userlab:1":{"01001001"},// 所有身份标签ID为2的用户身份标识"userlab:2":{"01001001"},// 用户ID为1的用户所有的标签状态位"useralllab:user:1":{"0101101011010010001"}
}

4.洗标签方式

采用redis队列+go协程来进行洗标签。结合go高并发来实现标签的快速清洗入库以及存储bitmaps

相关内容

热门资讯

鼎龙科技涨2.01%,成交额7... 1月7日,鼎龙科技盘中上涨2.01%,截至13:02,报24.32元/股,成交7714.38万元,换...
北部湾港股价涨5.08%,惠升... 1月7日,北部湾港涨5.08%,截至发稿,报9.92元/股,成交4.20亿元,换手率2.19%,总市...
精工钢构涨2.14%,成交额7... 1月7日,精工钢构盘中上涨2.14%,截至13:02,报4.29元/股,成交7448.07万元,换手...
耐科装备股价涨5.12%,益民... 1月7日,耐科装备涨5.12%,截至发稿,报30.38元/股,成交5601.71万元,换手率3.18...
大位科技股价涨5.14%,财通... 1月7日,大位科技涨5.14%,截至发稿,报8.39元/股,成交15.22亿元,换手率12.67%,...