面试JVM · Java虚拟机原理 · JVM上语言·框架· 生态系统Java

基于UUID算法实现全局ID

2021-10-16  本文已影响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

上一篇下一篇

猜你喜欢

热点阅读