雪花算法的由来

分布式ID生成规则

在这里插入图片描述

全局唯一

在这里插入图片描述

趋势递增

在这里插入图片描述

单调递增

在这里插入图片描述

信息安全

在这里插入图片描述

含时间戳

在这里插入图片描述

为啥递增?

现在mysql默认地存储引擎是InnoDB,索引是有序递增的。插入有序递增的id,索引直接在最后就维护了,如插入不是有序递增的,那么新的索引可能插入到头或中间位置,可能会导致页的分裂,维护索引耗费时间。

分布式ID生成系统的可用性要求

在这里插入图片描述

高可用

在这里插入图片描述

低延迟

在这里插入图片描述

高QPS

在这里插入图片描述

id生成

一般方案

在这里插入图片描述

UUID

在这里插入图片描述

在这里插入图片描述
满足了唯一性,但满足不了有序的要求,所以插入数据库的性能差。
在这里插入图片描述
在这里插入图片描述

数据可自增主键

在这里插入图片描述

单机

在这里插入图片描述
在这里插入图片描述

集群

在这里插入图片描述

Redis

在这里插入图片描述

snowflake

Twitter的分布式自增id算法snowflake

概述

在这里插入图片描述

结构

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

整合springboot

直接引用hutool或者githab下雪花源码。

hutool

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

package com.wh.config;

import cn.hutool.core.lang.Snowflake;
import cn.hutool.core.net.NetUtil;
import cn.hutool.core.util.IdUtil;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

import javax.annotation.PostConstruct;

/**
 * @author wanghao
 * @date 2021/7/18 20:15
 */
@Component
@Slf4j
public class IdGeneratorSnowflake {
    private long workerId = 0;
    private long datacenterId = 0;

    private Snowflake snowflake = IdUtil.createSnowflake(workerId, datacenterId);


    @PostConstruct
    public void init() {
        try {
            workerId = NetUtil.ipv4ToLong(NetUtil.getLocalhostStr());
            log.info("当前机器的workerId:{}" + workerId);
        } catch (Exception e) {
            e.printStackTrace();
            log.info("当前机器的workerId获取失败", e);
            workerId = NetUtil.getLocalhostStr().hashCode();
        }
    }
    public synchronized long snowflakeId(){
        return snowflake.nextId();
    }
    public synchronized long snowflakeId(long workerId,long datacenterId){
         snowflake = IdUtil.createSnowflake(workerId, datacenterId);
         return snowflake.nextId();
    }
}

优缺点

在这里插入图片描述

面试非要问时钟回拨?

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值