不能出现重复的ID,全局惟一是最基本的要求。html
业务上分页查询需求,排序需求,若是ID直接有序,则没必要创建更多的索引,增长查询条件。 并且Mysql InnoDB存储引擎主键使用汇集索引,主键有序则写入性能更高。java
ID是一条数据的惟一标识,若是ID生成失败,则影响很大,业务执行不下去。因此好的ID方案须要有高可用。git
ID虽然趋势有序,可是不能够被看出规则,省得被爬取信息。 了解到一个有意思的事情:基于MAC地址生成UUID的算法形成的MAC地址泄露,这个漏洞曾被用于寻找梅丽莎病毒的制做者位置。github
UUID(Universally Unique Identifier)是最简单的生成方案了:redis
UUID.randomUUID().toString()
生成形如:e811b49b-9ac1-47dc-8ab9-98fa7dd861d0的8-4-4-4-12的字符串。算法
snowflake是twitter开源的分布式ID生成算法,核心思想是:一个Long类型的ID,其中41bit做为毫秒数,10bit做为机器码,12bit做为毫秒内序列号。 sql
这个方案的思路时采用了MySQL自增加ID的机制(auto_increment auto_increment_offset)。数据库
经过使用如下SQL获取不一样的ID:安全
begin; REPLACE INTO Tickets64 (stub) VALUES ('a'); SELECT LAST_INSERT_ID(); commit;
在分布式系统中,多部署几台Mysql,每台机器的初始值不一样,步数与机器数量相等。 假设部署N台机器,步数为N,每台机器初始值依次为:0、一、2...N-1,架构以下: 服务器
基于redis的lua也能够作Flickr方案,生成的ID为64位:
最终ID:((second * 1000 microSecond / 1000) << (12 10)) (shardId << 10) seq;
也能够直接使用INCR或者HINCRBY来作ID生成方案,由于Redis的单线程原子性,性能也很不错。
uid-generator是基于Twitter开源的snowflake算法实现,须要依赖Mysql。 Github: baidu/uid-generator 具体文档参考Github。
Leaf——美团点评分布式ID生成系统 Github: Meituan-Dianping/Leaf
支持号段模式与snowflake模式。
Github: XiaoMi/chronos Chronos依赖ZooKeeper,ChronosServer运行时会启动一个Thrift服务器。
【分布式全局ID】细聊分布式ID生成方法 ID生成器,Twitter的雪花算法(Java) Leaf——美团点评分布式ID生成系统 万亿级调用系统:微信序列号生成器架构设计及演变 使用Redis实现高并发分布式序列号生成服务 分布式ID方案有哪些以及各自的优劣势,咱们当如何选择 分布式ID生成器解决方案 分布式全局序列ID方案之Redis优化方案 [分布式惟一ID极简教程](http://baijiahao.baidu.com/s?id=1584913615817222458