python中UUID模块解析

UUID(全称为Universally Unique IDentifier)是128位的全局唯一标识符。UUID是一个128比特的数值,这个数值可以通过一定的算法计算出来。为了提高效率,常用的UUID可缩短至16位。保证在一定的空间和时间上的唯一性,通常定义用来做唯一标识对象。

UUID通过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的唯一性,目前一共有五种算法,分别是uuid1,uuid2,uuid3,uuid4,uuid5,其中python中没有基于DCE的,所以在python中uuid2算法可以忽略。

uuid1

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

uuid3

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

uuid4

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

uuid5

基于名字的SHA-1散列值 算法与uuid3相同,不同的是使用 Secure Hash Algorithm 1 算法。

在上述四种算法中,如果是需要在分布式计算环境下,最好使用uuid1算法,uuid4存在概率性重复,所以需要慎用,对名字有唯一性需要建议使用uuid3和uuid5。

下面我们来看看具体使用方法

#!/usr/bin/python3
#coding:utf-8
import uuid
#uuid1
print(uuid.uuid1())
#uuid3
print(uuid.uuid3(uuid.uuid1(), "default"))
#uuid4
print(uuid.uuid4())
#uuid5
print(uuid.uuid5(uuid.uuid1(), "default"))

uuid3和uuid5函数参数如下

(function) def uuid5(
    namespace: UUID,
    name: str
) -> UUID

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://sulao.cn/post/920.html

我要评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。