php UUID &分布式生成用不重复的随机数方法

UUID(Universally Unique Identifier),通用惟一识别码。
UUID是指在一台机器上生成的数字,它保证对在同一时空中的全部机器都是惟一的php

UUID 由如下几个部分组成:
1)当前日期和时间
2)时钟序列
3)全局惟一的IEEE机器识别号,若是有网卡,从网卡MAC地址得到,没有网卡以其余方式得到。redis

 

生成 uuid:算法

public function create_guid($namespace = '') {
        static $guid = '';
        $uid = uniqid("", true);
        $data = $namespace;
        $data .= $_SERVER['REQUEST_TIME'];
        $data .= $_SERVER['HTTP_USER_AGENT'];
        $data .= $_SERVER['LOCAL_ADDR'];
        $data .= $_SERVER['LOCAL_PORT'];
        $data .= $_SERVER['REMOTE_ADDR'];
        $data .= $_SERVER['REMOTE_PORT'];
        $hash = strtoupper(hash('md5', $uid . $guid . md5($data)));
        $guid = '{' .
            substr($hash, 0, 8) .
            '-' .
            substr($hash, 8, 4) .
            '-' .
            substr($hash, 12, 4) .
            '-' .
            substr($hash, 16, 4) .
            '-' .
            substr($hash, 20, 12) .
            '}';
        return $guid;
    }

 

 

生成 logid:根据时序生成的 id数据库

public static function logid(){
        $arr = gettimeofday();
        $aa = ($arr['sec']*100000 + $arr['usec']/10) &  0x7FFFFFFF;
        $logId = ((($arr['sec']*100000 + $arr['usec']/10) & 0x7FFFFFFF) | 0x80000000);
       return $logId

    }

snowflake:并发

twitter在把存储系统从MySQL迁移到Cassandra的过程当中因为Cassandra没有顺序ID生成机制,因而本身开发了一套全局惟一ID生成的服务:snowflake。其核心思想是:一个long型的ID,使用其中41bit做为毫秒数,10bit做为机器编号,12bit做为毫秒内序列号。 运维

 

 

总结

算法高并发

优势ui

缺点spa

适用场景code

auto_increment

数据库本身实现,使用方便

存在单点问题,且有写入瓶颈

业务体量较小,并发数小,绝对递增

uuid 本地生成时效性高 须要独立部署和维护,string类型作索引查询效率低,极低几率出现重复 高并发、趋势递增
snowflake 本地生成时效性高 须要独立部署和维护 高并发、趋势递增
redis incr 实现灵活、简单 须要一次redis调用 并发要求不高,趋势递增
idalloc 内部维护服务 须要独立部署和运维 高并发,趋势递增
相关文章
相关标签/搜索