基于UUID算法实现全局ID

作者: 迦叶_金色的人生_荣耀而又辉煌 | 来源:发表于2021-10-16 08:30 被阅读0次

上一篇 <<<基于数据库自增方式实现全局ID
下一篇 >>>基于Twitter的snowflake(雪花)算法实现全局ID


利用全球唯一UUID生成订单号 一般UUID在生成Token领域使用比较多

UUID基本概念

UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。

UUID组成部分

当前日期和时间+时钟序列+随机数+全局唯一的IEEE机器识别号
全局唯一的IEEE机器识别号:如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。

优点

简单,代码方便
生成ID性能非常好,基本不会有性能问题
全球唯一,在遇见数据迁移,系统数据合并,或者数据库变更等情况下,可以从容应对

缺点

没有排序,无法保证趋势递增
UUID往往是使用字符串存储,查询的效率比较低
存储空间比较大,如果是海量数据库,就需要考虑存储量的问题。
传输数据量大

36位,中间的“-”是用来区分组成部分的,可以直接去掉
写法:

String uuid = UUID.randomUUID().toString().replace("-", "”);

推荐阅读:
<<<分布式全局ID生成总览
<<<基于数据库自增方式实现全局ID
<<<基于Twitter的snowflake(雪花)算法实现全局ID
<<<基于Redis生成全局ID

相关文章

网友评论

    本文标题:基于UUID算法实现全局ID

    本文链接:https://www.haomeiwen.com/subject/irfvnltx.html