python模块之uuid模块
uuid有什么用?
很多应用场景需要一个id,但是又不要求这个id 有具体的意义,仅仅用来标识一个对象。常见的用处有数据库表的id字段;用户session的key值;前端的各种UI库,因为它们通常需要动态创建各种UI元素,这些元素需要唯一的id, 这时候就需要使用UUID了。例如:一个网站在存储视频、图片等格式的文件时,这些文件的命名方式就可以采用 UUID生成的随机标识符,避免重名的出现
Python中uuid模块
uuid主要有五个算法,也就是五种方法来实现
python的uuid模块提供的UUID类和函数uuid1(),uuid3(),uuid4(),uuid5() 来生成1, 3, 4, 5各个版本的UUID ( 需要注意的是:Python中没有基于 DCE 的,所以uuid2可以忽略,其他语言中是有的。
uuid.uuid1(node clock_seq)
# 基于时间戳
# 使用主机ID, 序列号, 和当前时间来生成UUID, 可保证全球范围的唯一性.
# 但由于使用该方法生成的UUID中包含有主机的网络地址, 因此可能危及隐私.
# 该函数有两个参数, 如果 node 参数未指定, 系统将会自动调用 getnode() 函数来获取主机的硬件(mac)地址.
# 如果 clock_seq 参数未指定系统会使用一个随机产生的14位序列号来代替.
import uuid
print(uuid.uuid1())
uuid.uuid3(namespace, name)
# 通过计算名字和命名空间的MD5散列值得到,保证了同一命名空间中不同名字的唯一性,
# 和不同命名空间的唯一性,***但同一命名空间的同一名字生成相同的uuid****。
print(uuid.uuid3(uuid.NAMESPACE_URL,'python'))
print(uuid.uuid3(uuid.NAMESPACE_URL,'python'))
uuid.uuid4() : 基于随机数
# 通过随机数来生成UUID. 使用的是伪随机数有一定的重复概率.
print(uuid.uuid4())
uuid.uuid5(namespace, name)
# 通过计算命名空间和名字的SHA-1散列值来生成UUID, 算法与 uuid.uuid3() 相同
print(uuid.uuid5(uuid.NAMESPACE_URL,'python'))
总结
1 Python中没有基于 DCE 的,所以uuid2可以忽略
2 uuid4存在概率性重复,由无映射性
3 若在Global的分布式计算环境下,最好用uuid1
4 若有名字的唯一性要求,最好用uuid3或uuid5