雪花算法、uuid和自增id的区别
创始人
2024-05-31 20:03:55
0

自增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:

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

可以以业务实际user id为主键 比如QQ号 手机号等。

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

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


雪花id :

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

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

适用于大规模分布式

优点:

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

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

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

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

缺点:

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

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...