只需一步,快速开始
主题 896|帖子 896|积分 2688
一个美女面试官坐到我的对面,发光logo的MacBook也挡不住她那圆润可爱的脸庞。
啥?订单ID怎么生成?美女怎么不按套路出牌!HashMap实现原理,我已经倒背如流,你不问。瞎问什么订单ID。
全局唯一:如果订单ID重复了,肯定要完蛋。 高性能:要做到高并发、低延迟。生成订单ID都成为瓶颈了,那还得了。 高可用:至少要做到4个9,别动不动就宕机了。 易用性:如果为了满足上述要求,搞了几百台服务器,复杂且难以维护,也不行。 数值且有序递增:数值占用的空间更小,有序递增能保证插入MySQL的时候更高性能。 嵌入业务含义:如果订单ID里面能嵌入业务含义,就能通过订单ID知道是哪个业务线生成的,便于排查问题。
第 1 位: 符号位,暂时不用。 第 2~42 位: 共41位,时间戳,单位是毫秒,可以支撑大约69年 第 43~52 位: 共10位,机器ID,最多可容纳1024台机器 第 53~64 位: 共12位,序列号,是自增值,表示同一毫秒内产生的ID,单台机器每毫秒最多可生成4096个订单ID
您需要 登录 才可以下载或查看,没有账号?立即注册
使用道具 举报
本版积分规则 发表回复 回帖并转播 回帖后跳转到最后一页
缠丝猫