分布式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



原创粉丝点击