zoukankan      html  css  js  c++  java
  • 【算法】利用雪花算法生成分布式唯一ID

    上代码

    <?php
    /**
     *  分布式 id 生成类     组成: <毫秒级时间戳+机器id+序列号>
     *  默认情况下41bit的时间戳可以支持该算法使用到2082年,10bit的工作机器id可以支持1023台机器,序列号支持1毫秒产生4095个自增序列id
     *  @author zhangqi
     */
    class IdCreate
    {
        const EPOCH = 1606892626000;    //开始时间,固定一个小于当前时间的毫秒数
        const max12bit = 4095;
        const max41bit = 1099511627775;
    
        static $machineId = null;      // 机器id
    
        public static function machineId($mId = 0)
        {
            self::$machineId = $mId;
        }
    
        public static function createOnlyId()
        {
            // 时间戳 42字节
            $time = floor(microtime(true) * 1000);
            // 当前时间 与 开始时间 差值
            $time -= self::EPOCH;
            // 二进制的 毫秒级时间戳
            $base = decbin(self::max41bit + $time);
            // 机器id  10 字节
            if(!self::$machineId)
            {
                $machineid = self::$machineId;
            }
            else
            {
                $machineid = str_pad(decbin(self::$machineId), 10, "0", STR_PAD_LEFT);
            }
            // 序列数 12字节
            $random = str_pad(decbin(mt_rand(0, self::max12bit)), 12, "0", STR_PAD_LEFT);
            // 拼接
            $base = $base.$machineid.$random;
            // 转化为 十进制 返回
            return bindec($base);
        }
    }
    IdCreate::machineId("1");//机器编号
    echo IdCreate::createOnlyId();//分布式id
    ?>
    
    
  • 相关阅读:
    04-Go语言之运算符
    02-Go语言之变量和常量
    idea 无法加载识别本地类
    阿里云OSS实践篇
    jemeter 压测入门篇(附带工具)
    SpringBoot 中的那些“开关”
    java8 新特性之4大函数式接口
    java8 新特性之optional
    VSCode vue开发前配置
    前端架构演进及主流UI
  • 原文地址:https://www.cnblogs.com/richerdyoung/p/14073881.html
Copyright © 2011-2022 走看看