PHP雪花算法

雪花算法(Snowflake Algorithm)是一种分布式唯一ID生成算法,旨在满足分布式系统中对唯一标识的需求。它由Twitter公司的工程师Snowman(Snowflake的创造者)设计,用于生成全局唯一的ID,以应对分布式系统中唯一性标识的需求。

雪花算法的特点是简单、高效,且生成的ID是递增的,具有一定的时间顺序性。它的核心思想是将64位的ID划分为不同的部分,分别表示时间戳、机器节点ID和序列号,保证生成的ID在不同节点之间不冲突,且在同一节点上保持唯一性。

以下是雪花算法的组成部分:

  1. 时间戳(41位): 使用当前时间戳减去一个固定的起始时间戳,可以获得一个相对于起始时间的时间差,用41位来表示这个差值,精确到毫秒级别。

  2. 机器节点ID(10位): 分配给每个节点的唯一标识,可以手动配置或通过一定的分配算法生成。

  3. 序列号(12位): 在同一毫秒内产生的ID的序列号,支持每个节点每毫秒产生4096个唯一ID。

雪花算法生成的ID格式如下:

| 时间戳(41位) | 机器节点ID(10位) | 序列号(12位) |

由于时间戳占据了大部分位数,所以生成的ID在一定程度上是有序的,方便在数据库索引上的排序。雪花算法的分布式特性使得各个节点生成的ID不会冲突,同时保持了一定的时序性。

使用雪花算法时需要注意的是,节点ID的分配需要保证唯一性,且序列号需要在同一毫秒内不重复。当系统中的节点数量较大或者ID生成速度较快时,可能需要对算法进行一些调整,以确保其稳定性和性能。

<?php/*** 雪花ID算法*/
class Snowflake
{// 定义雪花ID的各部分位数private static $TIMESTAMP_BITS = 41; // 时间戳位数private static $NODE_ID_BITS = 10;    // 节点ID位数private static $SEQUENCE_BITS = 12;   // 序列号位数// 定义起始时间戳(这里以2020-01-01为例)private static $EPOCH = 1577836800000;// 定义最大取值范围private static $MAX_NODE_ID;private static $MAX_SEQUENCE;// 定义偏移量private static $TIMESTAMP_SHIFT;private static $NODE_ID_SHIFT;private $nodeId;private $lastTimestamp = -1;private $sequence = 0;public function __construct($nodeId){// 初始化静态属性self::$MAX_NODE_ID = (1 << self::$NODE_ID_BITS) - 1;self::$MAX_SEQUENCE = (1 << self::$SEQUENCE_BITS) - 1;self::$TIMESTAMP_SHIFT = self::$NODE_ID_BITS + self::$SEQUENCE_BITS;self::$NODE_ID_SHIFT = self::$SEQUENCE_BITS;if ($nodeId < 0 || $nodeId > self::$MAX_NODE_ID) {throw new InvalidArgumentException("Invalid node ID");}$this->nodeId = $nodeId;}public function generateId(){$currentTimestamp = $this->timestamp();if ($currentTimestamp < $this->lastTimestamp) {throw new RuntimeException("Clock moved backwards");}if ($currentTimestamp == $this->lastTimestamp) {$this->sequence = ($this->sequence + 1) & self::$MAX_SEQUENCE;if ($this->sequence == 0) {$currentTimestamp = $this->untilNextMillis($this->lastTimestamp);}} else {$this->sequence = 0;}$this->lastTimestamp = $currentTimestamp;return (($currentTimestamp - self::$EPOCH) << self::$TIMESTAMP_SHIFT) |($this->nodeId << self::$NODE_ID_SHIFT) |$this->sequence;}private function timestamp(){return round(microtime(true) * 1000);}private function untilNextMillis($lastTimestamp){$currentTimestamp = $this->timestamp();while ($currentTimestamp <= $lastTimestamp) {$currentTimestamp = $this->timestamp();}return $currentTimestamp;}
}// 例子使用
$nodeId = 1; // 设置节点 ID
$snowflake = new Snowflake($nodeId);
$id = $snowflake->generateId();echo '<pre>';
var_dump($id);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/654504.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

并查集的学习

并查集可以理解为数学上的集合 并查集一般以树这种数据结构来储存每一个元素&#xff0c;判断两个元素是否为同一个集合&#xff0c;通常判断两个元素所在的树的根结点是否相同&#xff0c;因为比较两个元素是否是同一个树要向上查找根结点&#xff0c;所以一般用双亲表示法&a…

Sphinx的原理详解和使用

一、Sphinx介绍 1.1 简介 Sphinx是由俄罗斯人Andrew Aksyonoff开发的一个全文检索引擎。意图为其他应用提供高速、低空间占用、高结果 相关度的全文搜索功能。Sphinx可以非常容易的与SQL数据库和脚本语言集成。当前系统内置MySQL和PostgreSQL 数据库数据源的支持&#xff0c;也…

限时回归!!!3D版《空洞骑士》!!!

空洞骑士是一款基于横板平台跳跃的传统风格2D动作冒险游戏。庞大的游戏世界交错相通&#xff0c;玩家控制小虫子去探索幽深黑暗的洞穴&#xff0c;成为了一代人茶余饭后的惦念&#xff0c;深受广大玩家们的喜爱。 这类平台跳跃游戏一般是游戏开发初学者以及独立游戏开发者们比…

【DRAM存储器十八】DDR3介绍

&#x1f449;个人主页&#xff1a;highman110 &#x1f449;作者简介&#xff1a;一名硬件工程师&#xff0c;持续学习&#xff0c;不断记录&#xff0c;保持思考&#xff0c;输出干货内容 参考资料&#xff1a;《镁光DDR3数据手册》 、《JESD79-3E》 最近忙于工作&#xff0…

Linux使用匿名管道实现进程池得以高效通信

&#x1f3ac;慕斯主页&#xff1a;修仙—别有洞天 ♈️今日夜电波&#xff1a;Nonsense—Sabrina Carpenter 0:50━━━━━━️&#x1f49f;──────── 2:43 &#x1f504; ◀️ ⏸ ▶️ …

python基础四------完结(概念在下面,代码看不懂了再看)

# a_list [1,2,3,4,5] # # print(a_list)# 根据下标来删除列表中的元素 # 爬取的数据中 有个别的数据 是我们不想要的 那么我们就可以通过下标的方式来删除 # del a_list[2] # print(a_list)# b_list [1,2,3,4,5] # print(b_list) # pop是删除列表中的最后一个元素 # b_list.…

stack Error: EACCES: permission denied

报错 stack Error: EACCES: permission denied解决 npm install webpack --save-dev --unsafe-perm参考 npm报错stack Error: EACCES: permission denied, mkdir

Kali 基本命令大全

一、系统信息 arch 显示机器的处理器架构(1) uname -m 显示机器的处理器架构(2) uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件- (SMBIOS / DMI) hdparm -i /dev/hda 罗列一个磁盘的架构特性 hdparm -tT /dev/sda 在磁盘上执行测试性读取操作 cat /proc/cpu…

蓝桥杯-岛屿个数-bfs-dfs算法

小蓝得到了一副大小为 M N 的格子地图&#xff0c;可以将其视作一个只包含字符‘0’&#xff08;代表海水&#xff09;和 ‘1’&#xff08;代表陆地&#xff09;的二维数组&#xff0c;地图之外可以视作全部是海水&#xff0c;每个岛屿由在上/下/左/右四个方向上相邻的 ‘1’…

AP5216 平均电流型LED降压恒流驱动IC 手电筒汽车摩托车灯芯片

产品描述 AP5216 是一款 PWM工作模式, 高效率、外围简单、内置功率管&#xff0c;适用于5V&#xff5e;100V输入的高精度降压 LED 恒流驱动芯片。输出最大功率可达9W&#xff0c;最大电流 1.0A。AP5216 可实现全亮/半亮功能切换&#xff0c;通过MODE 切换&#xff1a;全亮/半亮…

SAP HANA 报错信息,如何根据报错关键词去进行处理

HANA建模其实上手会比较快&#xff0c;基本会SQL就可以进行开发。 在实际开发中&#xff0c;难点一个是建模思路&#xff0c;另外一个则是建模中报错的处理。 现在将HANA中报错进行一个整理&#xff0c;这里的并不是完整的报错信息&#xff0c;大家可以根据关键词进行查看。 …

ChatGPT更新了Mention功能,集结若干GPTs作战,AI智能体的心智入口;向量数据库的挑战和未来

&#x1f989; AI新闻 &#x1f680; ChatGPT更新了Mention功能&#xff0c;集结若干GPTs作战&#xff0c;AI智能体的心智入口 摘要&#xff1a;OpenAI在ChatGPT中引入了一个新功能&#xff0c;允许用户在聊天时任意一个GPTs&#xff08;即ChatGPT最新推出的AI Agent 智能应用…

scrapy的入门使用

1 安装scrapy 命令: sudo apt-get install scrapy或者&#xff1a; pip/pip3 install scrapy2 scrapy项目开发流程 创建项目: scrapy startproject mySpider生成一个爬虫: scrapy genspider itcast itcast.cn提取数据:     根据网站结构在spider中实现数据采集相关内…

五、MySQL的备份及恢复

5.1 MySQL日志管理 在数据库保存数据时&#xff0c;有时候不可避免会出现数据丢失或者被破坏&#xff0c;这样情况下&#xff0c;我们必须保证数据的安全性和完整性&#xff0c;就需要使用日志来查看或者恢复数据了 数据库中数据丢失或被破坏可能原因&#xff1a; 误删除数据…

C/C++ - 函数进阶(C++)

目录 默认参数 函数重载 内联函数 函数模板 递归函数 回调函数 默认参数 定义 默认参数是在函数声明或定义中指定的具有默认值的函数参数。默认参数允许在调用函数时可以省略对应的参数&#xff0c;使用默认值进行替代。 使用 默认参数可以用于全局函数和成员函数。默认参…

C语言KR圣经笔记 5.12 复杂声明

5.12 复杂声明 C 语言有时会因为声明的语法而受到谴责&#xff0c;特别是涉及函数指针的声明语法。语法试图使声明和使用一致&#xff1b;在简单的情况下它的效果不错&#xff0c;但在更复杂的情况下会让人困惑&#xff0c;因为声明不能从左往右读&#xff0c;而且括号被过度使…

Linux文本三剑客---sed经典案例

Sed介绍&#xff1a; sed是一种流编辑器&#xff0c;它一次处理一行内容。处理时&#xff0c;把当前处理的行存储在临时缓冲区中&#xff0c;称为“模式空间”&#xff0c;接着用sed命令处理缓冲区中的内容&#xff0c;处理完成后&#xff0c;把缓冲区的内容送往屏幕。接着处理…

Mybatis-plus原生pages分页未生效的解决方案

文章目录 前言原因1、Mybatis Plus版本的问题2、Mapper.xml文件中SQL语句格式问题3、Mybatis Plus默认分页拦截器问题4、分页参数传参问题5、分页配置的问题 解决方案1、升级对应的Mybatis-plus版本分页插件配置问题3、自定义分页拦截器4、正确的参数5、不同版本的配置文件3.4.…

Hugging Face创始人分享:企业如何在ChatGPT浪潮下实现战略布局

Hugging Face创始人兼首席执行官 Clem Delangue在IBM一年一度的 THINK大会中研讨了当前人工智能发展趋势&#xff0c;特别是ChatGPT模型以及其对行业的影响。他的演讲还涉及到一个关键的议题&#xff0c;在ChatGPT这样的通用模型出现后&#xff0c;企业如何在人工智能领域找到自…

QR 分解cpu程序

1. 代码 Makefile EXE : hello_qrSRC_QR qr_main.c qr_func.c $(EXE): $(SRC_QR)gcc $^ -o $ -lm.PHONY: clean clean:-rm -rf $(EXE) qr_main.c #include "stdio.h"int maqr(double* a,int m,int n,double* q);int main() {int i,j;static double q[4][4],a[4]…