技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> 算法 --> Python模块学习之UUID

Python模块学习之UUID

浏览:3078次  出处信息

    UUID是128位的全局唯一标识符,通常由32字节的字符串表示。它可以保证时间和空间的唯一性,也称为GUID,全称为:

  • UUID —— Universally Unique IDentifier Python 中叫 UUID
  • GUID —— Globally Unique IDentifier C# 中叫 GUID
  •     它通过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的唯一性。

        

        UUID主要有五个算法,也就是五种方法来实现:

        1、uuid1()——基于时间戳

        由MAC地址、当前时间戳、随机数生成。可以保证全球范围内的唯一性,但MAC的使用同时带来安全性问题,局域网中可以使用IP来代替MAC。

        2、uuid2()——基于分布式计算环境DCE(Python中没有这个函数)

         算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。实际中很少用到该方法。

        3、uuid3()——基于名字的MD5散列值

         通过计算名字和命名空间的MD5散列值得到,保证了同一命名空间中不同名字的唯一性,和不同命名空间的唯一性,但同一命名空间的同一名字生成相同的uuid。

        4、uuid4()——基于随机数

        由伪随机数得到有一定的重复概率,该概率可以计算出来。

        5、uuid5()——基于名字的SHA-1散列值

        算法与uuid3相同,不同的是使用 Secure Hash Algorithm 1 算法

        python提供的生成uuid的方法一共有4种,分别是:

  • 从硬件地址和时间生成
  • 从md5算法生成
  • 随机生成
  • 从SHA-1算法生成
  •     在uuid模块里对应uuid1, uuid3, uuid4, uuid5这几个方法,注意没有uuid2。下面是示例:

        import uuid

        print uuid.uuid1()

        print uuid.uuid3(uuid.NAMESPACE_DNS, ‘www.biaodianfu.com’)

        print uuid.uuid4()

        print uuid.uuid5(uuid.NAMESPACE_DNS, ‘www.biaodianfu.com’)

        参考地址:http://docs.python.org/library/uuid.html

    建议继续学习:

    1. 分布式系统中唯一ID的生成    (阅读:2306)
    2. VirtualBox 虚拟机镜像文件 UUID 已存在问题    (阅读:1288)
    QQ技术交流群:445447336,欢迎加入!
    扫一扫订阅我的微信号:IT技术博客大学习
    © 2009 - 2024 by blogread.cn 微博:@IT技术博客大学习

    京ICP备15002552号-1