雪花算法、uuid和自增id的区别

自增id:

自增的主键的值是顺序的。

优点: 1.自增,趋势自增,可作为聚集索引,提升查询效率 2.节省磁盘空间。500W数据,UUID占5.4G,自增ID占2.5G. 3.查询,写入效率高:查询略优。在数据量大时候高于uuid插入速度

缺点: 1.导入旧数据时,可能会ID重复,导致导入失败。 2.分布式架构,多个Mysql实例可能会导致ID重复。 3.容易被外界攻破,知道业务实际情况。且例如:显示公告内容index?id=3这样就很容易被人篡改为index?id=2.就可以调到第二条的内容。 4对于分库操作,id不能重复,所以我们最好使先从MySQL获取一批自增ID,加载到本地内存中,然后从内存中取。

UUID:

在一定的范围内唯一的机器生成的标识符,通用唯一标识符

优点:随机生成,不会重复。

缺点:uuid中带有字符串,32位字符串会占用更大的空间,无序的字符串作数据库主键,每次插入数据库的时候,MySQL为了维护B+树结构,需要频繁调整节点顺序,影响性能。


雪花id :

相比UUID无序生成的id而言,雪花算法是有序的(有时间参数),而且都是由数字组成。

雪花id最大为64位,符合java中long的长度64位。

适用于大规模分布式

优点:

1.引入了时间戳,保证ID能够按照时间有序生成,索引效率高

2.分布式系统不会产生ID碰撞,并且效率较高

3.高性能高可用:不依赖第三方库或者中间件,完全在内存中生成,可用性强

4.容量大:每秒中能生成数百万的自增ID。

缺点:

依赖与系统时间的一致性,如果系统时间被回调,或者改变,可能会造成id冲突或者重复。

经验分享 程序员 微信小程序 职场和发展