分布式id生成器
来源:互联网 发布:jmeter响应数据乱码 编辑:程序博客网 时间:2024/06/05 07:26
场景:需要在分布式环境下生成永远不会重复的数字类型的id,
组成: 毫秒级时间戳+机器id+序列号(雪花算法,snowflack)
(之前本来用 md5() 生成的唯一ID ,不过是字符串类型的,数据量上万时,查询效率直降)
Linux环境下,生成长度是 16位的数字,逐增;Windows环境下,生成长度 14位,逐增;
id生成类:
/** * 分布式 id 生成类 组成: <毫秒级时间戳+机器id+序列号> * 默认情况下41bit的时间戳可以支持该算法使用到2082年,10bit的工作机器id可以支持1023台机器,序列号支持1毫秒产生4095个自增序列id * @author zhangqi */class IdCreate{ const EPOCH = 1479533469598;//开始时间,固定一个小于当前时间的毫秒数 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);}}调用:
$machineId = 1;IdCreate::createOnlyId($machineId);
结果示例
Linux 下:4643055919074148
windows下:16306363872456
阅读全文
1 0
- 分布式ID生成器
- 分布式id生成器,互联网
- 分布式系统ID生成器
- 分布式ID生成器
- 分布式ID生成器解决方案
- 分布式ID生成器
- 【分布式ID生成器】
- 分布式id生成器
- php+redis+lua+id生成器,分布式id生成器
- 基于redis的分布式ID生成器
- 基于redis的分布式ID生成器
- 分布式唯一ID生成器Twitter 的 Snowflake idworker java版本
- ZooKeeper 实现命名服务(分布式的ID生成器)
- 编写一个springboot start 类型的分布式全局id生成器
- id生成器
- ID生成器
- ID生成器
- ID生成器
- jsonp实现跨域
- cpu之stall_ctr
- 安卓内存-UI流畅度
- hadoop集群之间迁移分区表
- JavaWeb项目为什么我们要放弃jsp?为什么要前后端解耦?为什么要动静分离?
- 分布式id生成器
- MySQL异常:ERROR 1045 (28000): Unknown error 1045
- Mybatis代码生成器:mybatis-generator (maven方式)
- SSM框架集成(另有增删改查案例,及数据库备份)
- [js]文件上传
- Java编程规范
- 游戏开发学习笔记(十一)装备的穿戴卸下处理
- 数据库设计
- REPL