6-9 雪花算法与新增功能
Posted 孤注一掷 、
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了6-9 雪花算法与新增功能相关的知识,希望对你有一定的参考价值。
新增工具类:
/**
* Twitter的分布式自增ID雪花算法
**/
@Component
public class SnowFlake
/**
* 起始的时间戳
*/
private final static long START_STMP = 1609459200000L; // 2021-01-01 00:00:00
/**
* 每一部分占用的位数
*/
private final static long SEQUENCE_BIT = 12; //序列号占用的位数
private final static long MACHINE_BIT = 5; //机器标识占用的位数
private final static long DATACENTER_BIT = 5;//数据中心占用的位数
/**
* 每一部分的最大值
*/
private final static long MAX_DATACENTER_NUM = -1L ^ (-1L << DATACENTER_BIT);
private final static long MAX_MACHINE_NUM = -1L ^ (-1L << MACHINE_BIT);
private final static long MAX_SEQUENCE = -1L ^ (-1L << SEQUENCE_BIT);
/**
* 每一部分向左的位移
*/
private final static long MACHINE_LEFT = SEQUENCE_BIT;
private final static long DATACENTER_LEFT = SEQUENCE_BIT + MACHINE_BIT;
private final static long TIMESTMP_LEFT = DATACENTER_LEFT + DATACENTER_BIT;
private long datacenterId = 1; //数据中心
private long machineId = 1; //机器标识
private long sequence = 0L; //序列号
private long lastStmp = -1L;//上一次时间戳
public SnowFlake()
public SnowFlake(long datacenterId, long machineId)
if (datacenterId > MAX_DATACENTER_NUM || datacenterId < 0)
throw new IllegalArgumentException("datacenterId can't be greater than MAX_DATACENTER_NUM or less than 0");
if (machineId > MAX_MACHINE_NUM || machineId < 0)
throw new IllegalArgumentException("machineId can't be greater than MAX_MACHINE_NUM or less than 0");
this.datacenterId = datacenterId;
this.machineId = machineId;
/**
* 产生下一个ID
*
* @return
*/
public synchronized long nextId()
long currStmp = getNewstmp();
if (currStmp < lastStmp)
throw new RuntimeException("Clock moved backwards. Refusing to generate id");
if (currStmp == lastStmp)
//相同毫秒内,序列号自增
sequence = (sequence + 1) & MAX_SEQUENCE;
//同一毫秒的序列数已经达到最大
if (sequence == 0L)
currStmp = getNextMill();
else
//不同毫秒内,序列号置为0
sequence = 0L;
lastStmp = currStmp;
return (currStmp - START_STMP) << TIMESTMP_LEFT //时间戳部分
| datacenterId << DATACENTER_LEFT //数据中心部分
| machineId << MACHINE_LEFT //机器标识部分
| sequence; //序列号部分
private long getNextMill()
long mill = getNewstmp();
while (mill <= lastStmp)
mill = getNewstmp();
return mill;
private long getNewstmp()
return System.currentTimeMillis();
public static void main(String[] args) throws ParseException
// 时间戳
// System.out.println(System.currentTimeMillis());
// System.out.println(new Date().getTime());
//
// String dateTime = "2021-01-01 08:00:00";
// SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
// System.out.println(sdf.parse(dateTime).getTime());
SnowFlake snowFlake = new SnowFlake(1, 1);
long start = System.currentTimeMillis();
for (int i = 0; i < 10; i++)
System.out.println(snowFlake.nextId());
System.out.println(System.currentTimeMillis() - start);
雪花算法其实就是一个时间戳加上一些机器码,再加递增的序列号。
时间戳是 1609805322846 这样
而 2021-01-01 08:00:00 称为日期格式化
nextId()方法:首先会取一个时间戳,即跟2021年之差的时间戳。同一毫秒内,最多可以生成2的12次方个id...最后将 时间戳部分、数据中心部分、机器标识部分和序列号拼接起来,整个数字变为雪花id,长整型。
新增:
生成雪花id。
id有几种算法:1.最简单的自增,2.uuid,3.雪花算法
在table标签上新增:
测试:
新增成功。
以上是关于6-9 雪花算法与新增功能的主要内容,如果未能解决你的问题,请参考以下文章
华为运动健康服务Health Kit 6.9.0版本新增功能揭秘!
华为运动健康服务Health Kit 6.9.0版本新增功能揭秘!
雪花算法踩坑 - Long 类型 id 返回前端精度丢失 (通过序列化解决)