...
...
前言我们的数据库在设计时一般有两个ID,自增的id为主键,还有一个业务ID使用UUID生成。自增id在需要分表的情况下做为业务主键不太理想,所以我们增加了uuid作为业务ID,有了业务id仍然还存在自增id的原因具体我也说不清楚,只知道和插入的性能以及db的要求有关。 我个人一直想将这两个ID ...
1、新建一个id生成的类 SnowFlake 2、为防止多线程生成重复的id,这边新建了一个调用生成id的单例工具 其中machineId和datacenterId可以放在配置文件中 最后直接调用:GuuidUtil.getUUID();就可以直接生成id ...
...
Snowflake生成的是Long类型的ID,一个Long类型占8个字节,每个字节占8比特,也就是说一个Long类型占64个比特。 Snowflake ID组成结构:正数位(占1比特)+ 时间戳(占41比特)+ 机器ID(占5比特)+ 数据中心(占5比特)+ 自增值(占12比特),总共64比特 ...
分布式系统下 我们每台设备(分布式系统-独立的应用空间-或者docker环境) 所以我们可以为分布式系统下:分库分表主键,分库,多库的情况下的订单编号使用这种方式进行唯一number操作 虽然这种方法正常情况下还是可以凑合用的,但是假如设备出现时间差,在极度大的并发 ...
...
JavaScript生成有序GUID或者UUID,这时就想到了雪花算法。 原理介绍: snowFlake算法最终生成ID的结果为一个64bit大小的整数,结构如下图: 解释: 1bit。二进制中最高位为1表示负数,但是我们最终生成的ID一般都是整数,所以这个最高位固定 ...