面试刷题31:分布式ID设计方案
2020-04-06 16:05:21来源:博客园 阅读 ()
面试刷题31:分布式ID设计方案
面试中关于分布式的问题很多。(分布式事务,基本理论CAP,BASE,分布式锁)先来一个简单的。
简单说一下分布式ID的设计方案?
首先要明确在分布式环境下,分布式id的基本要求。
1, 全局唯一,在分布式集群下,不同的节点并发生成的分布式id要唯一;
2, 顺序性,分布式id是有序生成
然后给出分布式id的设计方案。
1, 基于数据的自增id生成分布式ID,使用比较简单,缺点是扩展性和可靠性有限;基于数据库表的自增id
2,基于snowflake 算法生成;
snowflake生成的分布式id是一个64位整数;位数标识如下:
1 标识正负
41位,一般使用System.currentTimeMilles()得到;
5 数据中心标识
5 机器ip标识
12 单位毫秒内可以生成的序数极限
snowflake的生成跟时间相关的使用的是System.currentTimeMilles(),跟冬令时没有关系。
分布式id的进一步要求
可靠性: 即高可用
紧凑性: 64位的整数比较长,不太紧凑,作为索引,存储不占优势。
有意义: 可以放入业务标识或者时间
snowflake的缺点
受时间影响:需要保证分布式集群的时间同步,即NTP ;?
可以预测到:容易按照时间规律预测到,进而影响安全性;
小结
回答了分布式id的基本要求,已经常用方案。
原创不易,点赞关注支持一下吧!转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。
我会持续分享Java软件编程知识和程序员发展职业之路,欢迎关注,我整理了这些年编程学习的各种资源,关注公众号‘李福春持续输出’,发送'学习资料'分享给你!
原文链接:https://www.cnblogs.com/snidget/p/12649844.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 2020年深圳中国平安各部门Java中级面试真题合集(附答案) 2020-06-11
- JVM常见面试题解析 2020-06-11
- 聊聊微服务架构及分布式事务解决方案! 2020-06-10
- 作为一个面试官,我想问问你Redis分布式锁怎么搞? 2020-06-10
- 送你一份年薪百万的抖音Java岗内部面试题 2020-06-09
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash