分布式id生成器
2017-12-18 15:48
726 查看
场景:需要在分布式环境下生成永远不会重复的数字类型的id,
组成: 毫秒级时间戳+机器id+序列号(雪花算法,snowflack)
(之前本来用 md5() 生成的唯一ID ,不过是字符串类型的,数据量上万时,查询效率直降)
Linux环境下,生成长度是 16位的数字,逐增;Windows环境下,生成长度 14位,逐增;
id生成类:
结果示例
Linux 下:4643055919074148
windows下:16306363872456
组成: 毫秒级时间戳+机器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
相关文章推荐
- 分布式唯一ID生成器Twitter 的 Snowflake idworker java版本
- php+redis+lua+id生成器,分布式id生成器
- Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】
- 分布式ID生成器PHP+Swoole实现(下) - 代码实现
- 分布式ID生成器
- Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】
- 编写一个springboot start 类型的分布式全局id生成器
- 基于redis的分布式ID生成器
- 分布式ID生成器的解决方案总结
- 分布式全局ID生成器设计
- Zookeeper系列(三十三)Zookeeper场景应用之分布式ID生成器
- 简单的分布式ID生成器
- 基于redis的分布式ID生成器
- 分布式ID生成器
- snowflake 分布式唯一ID生成器
- Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】
- 细聊分布式ID生成方法的实现(一个可以使用10年的序列生成器)
- Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】
- Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】
- Jedis使用总结【pipeline】【分布式的id生成器】【分布式锁【watch】【multi】】【redis分布式】