您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

如何设计百万级的用户ID

时间:2021-11-10 09:56:04  来源:  作者:飘在上海的程序员

前言

我们在进行平台账号体系设计的时候,遇到这么一个需求:在平台注册的用户ID以n位的数字展现。

乍一看,这个需求很简单,就一句话。但仔细思考后,发现这里面还是有很多地方需要思考的:

  • 用户ID是随机生成还是顺序自增?
  • 如果是随机生成的:
    • 如何保证每次生成的ID都是唯一的?
  • 如果是顺序自增的:
    • 是不是会泄露平台用户规模,增加安全隐患?
    • 如何保证分布式高并发下的ID顺序自增?
  • 如果用户数量达到n位数上限后,如何自动扩展ID?

思路

首先,先确定ID是自增还是随机,从上面的思考中,可以发现用户ID自增会带来一些安全隐患:如当系统存在某种bug,可以通过用户ID查询用户信息时,就会面临通过遍历用户ID,达到获取平台全量用户信息的隐私泄露问题。另外,自增也会暴露平台用户规模,不利于商业行为。所以,用户ID必须是随机生成。

那么,用户ID随机生成,如何保证每次都是一个唯一值呢?这里有两个思路:

  • 设计一种算法,通过数学运算,以一定的入参,得到一个一一映射的出参,该出参的范围在n为数字的大小范围内。数学表达式为:
y = f(x_0,x_1,...,x_m,n)

其中,m=入参个数,由m个入参确定唯一性,n=y的范围大小。

  • 借助于工程思想,利用各种中间件实现该需求。如借助与MySQL+redis

方案

针对第一个思路,可以参考唯一随机数映射算法

这里主要展开下使用工程思想,借助MySQL+Redis+定时器的实现方式。

在MySQL里创建一张表t_user_id_pool, 该表中放入所有符合条件的用户id,如000000-999999。

设计定时器逻辑为:每隔1小时,去redis中读取key为id_pool的键,

  • 如果id_pool不存在,则随机地从数据库中读取1000个用户id,以队列的形式存入redis的id_pool里;
  • 如果id_pool存在但队列里id数量小于等于200时,从数据库随机获取1000个用户id,push到redis的id_pool里。

业务侧生成用户id的时候,从redis的id_pool里pop一个值出来作为用户id。因为redis天然单线程结构,所以不用担心,高并发情况下会获取相同的id。

如何设计百万级的用户ID

 



Tags:用户ID   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
前言我们在进行平台账号体系设计的时候,遇到这么一个需求:在平台注册的用户ID以n位的数字展现。乍一看,这个需求很简单,就一句话。但仔细思考后,发现这里面还是有很多地方需要思...【详细内容】
2021-11-10  Tags: 用户ID  点击:(41)  评论:(0)  加入收藏
▌简易百科推荐
摘 要 (OF作品展示)OF之前介绍了用python实现数据可视化、数据分析及一些小项目,但基本都是后端的知识。想要做一个好看的可视化大屏,我们还要学一些前端的知识(vue),网上有很多比...【详细内容】
2021-12-27  项目与数据管理    Tags:Vue   点击:(1)  评论:(0)  加入收藏
程序是如何被执行的  程序是如何被执行的?许多开发者可能也没法回答这个问题,大多数人更注重的是如何编写程序,却不会太注意编写好的程序是如何被运行,这并不是一个好...【详细内容】
2021-12-23  IT学习日记    Tags:程序   点击:(9)  评论:(0)  加入收藏
阅读收获✔️1. 了解单点登录实现原理✔️2. 掌握快速使用xxl-sso接入单点登录功能一、早期的多系统登录解决方案 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器...【详细内容】
2021-12-23  程序yuan    Tags:单点登录(   点击:(8)  评论:(0)  加入收藏
下载Eclipse RCP IDE如果你电脑上还没有安装Eclipse,那么请到这里下载对应版本的软件进行安装。具体的安装步骤就不在这赘述了。创建第一个标准Eclipse RCP应用(总共分为六步)1...【详细内容】
2021-12-22  阿福ChrisYuan    Tags:RCP应用   点击:(7)  评论:(0)  加入收藏
今天想简单聊一聊 Token 的 Value Capture,就是币的价值问题。首先说明啊,这个话题包含的内容非常之光,Token 的经济学设计也可以包含诸多问题,所以几乎不可能把这个问题说的清...【详细内容】
2021-12-21  唐少华TSH    Tags:Token   点击:(9)  评论:(0)  加入收藏
实现效果:假如有10条数据,分组展示,默认在当前页面展示4个,点击换一批,从第5个开始继续展示,到最后一组,再重新返回到第一组 data() { return { qList: [], //处理后...【详细内容】
2021-12-17  Mason程    Tags:VUE   点击:(14)  评论:(0)  加入收藏
什么是性能调优?(what) 为什么需要性能调优?(why) 什么时候需要性能调优?(when) 什么地方需要性能调优?(where) 什么时候来进行性能调优?(who) 怎么样进行性能调优?(How) 硬件配...【详细内容】
2021-12-16  软件测试小p    Tags:性能调优   点击:(19)  评论:(0)  加入收藏
Tasker 是一款适用于 Android 设备的高级自动化应用,它可以通过脚本让重复性的操作自动运行,提高效率。 不知道从哪里听说的抖音 app 会导致 OLED 屏幕烧屏。于是就现学现卖,自...【详细内容】
2021-12-15  ITBang    Tags:抖音防烧屏   点击:(23)  评论:(0)  加入收藏
11 月 23 日,Rust Moderation Team(审核团队)在 GitHub 上发布了辞职公告,即刻生效。根据公告,审核团队集体辞职是为了抗议 Rust 核心团队(Core team)在执行社区行为准则和标准上...【详细内容】
2021-12-15  InfoQ    Tags:Rust   点击:(24)  评论:(0)  加入收藏
一个项目的大部分API,测试用例在参数和参数值等信息会有很多相似的地方。我们可以复制API,复制用例来快速生成,然后做细微调整既可以满足我们的测试需求1.复制API:在菜单发布单...【详细内容】
2021-12-14  AutoMeter    Tags:AutoMeter   点击:(20)  评论:(0)  加入收藏
相关文章
    无相关信息
最新更新
栏目热门
栏目头条