您的位置:首页 > 其它

分布式id生成器

2017-12-18 15:48 726 查看
场景:需要在分布式环境下生成永远不会重复的数字类型的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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: