雪花算法逆推创建时间

雪花算法逆推创建时间

雪花算法由 时间戳 + 机器码+ 序列化组成

github.com/sony/sonyflake中的雪花算法举例

![在这里插入图片描述](https://img-blog.csdnimg.cn/23645bacb8854a439ba53d257a50a966.png

源码如下

时间戳是从一个指定的startTime过去的时间。(从toSonyflakeTime可知时间进去到毫秒级的前1位)
在这里插入图片描述
得到id的位移方法
在这里插入图片描述

逆推方法

生成时间 = id >> (机器码位数 + 序列号位数) + 起始时间

package main

import (
	"fmt"
	"github.com/sony/sonyflake"
	"time"
)

func main() {
	var st sonyflake.Settings
	sf := sonyflake.NewSonyflake(st)
	if sf == nil {
		panic("sonyflake not created")
	}
	id, err := sf.NextID()
	if err != nil {
		panic(err)
	}

	startTime := toSonyflakeTime(st.StartTime)
	fmt.Println("gen id :", id)
	fmt.Println("start_time:", startTime)
	fmt.Println("spend:", time.Now().UnixMilli()-startTime.UnixMilli())
	t := id >> (sonyflake.BitLenMachineID + sonyflake.BitLenSequence)
	fmt.Println("need :", t)
	res := startTime.UnixNano()/1e7 + int64(t)
	fmt.Println(time.UnixMilli(res * 10))
	//279004813828
}
func toSonyflakeTime(t time.Time) time.Time {
	if t.IsZero() {
		return time.Date(2014, 9, 1, 0, 0, 0, 0, time.UTC)
	}
	return t.UTC()

}

结果如下

在这里插入图片描述

计算的作用

数据库进行分片如果是根据时间规则切分的,可以利用id直接计算出所在的表的分表名。能排除大量的查找。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值