基于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