雪花算法、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冲突或者重复。