分布式id生成器

14 篇文章 0 订阅
11 篇文章 1 订阅

场景:需要在分布式环境下生成永远不会重复的数字类型的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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值