UUID是通用唯一标识符(Universally Unique Identifier)的缩写,也叫GUID (Globally Unique Identifier)。它是一个由一串数字和字母组成的标识符,用于在计算机系统中唯一地标识实体(如文件、对象、数据库记录等)。UUID是由一组算法根据设备的网卡、时间戳、随机数计算得出的,保证了同一时空中没有两个UUID相同的可能性非常小。因此,UUID在分布式系统中被广泛使用,例如在数据库、操作系统、Web 应用程序和其他应用程序中用于标识和追踪唯一实体。
为什么要使用UUID?
很多应用场景需要一个id, 但是又不要求这个id 有具体的意义, 仅仅用来标识一个对象. 常见的例子有数据库表的id 字段. 另一个例子是前端的各种UI库, 因为它们通常需要动态创建各种UI元素, 这些元素需要唯一的id , 这时候就需要使用UUID了.
python的uuid模块:
提供UUID类和函数uuid1(), uuid3(), uuid4(), uuid5() 来生成1, 3, 4, 5各个版本的UUID ( 需要注意的是: python中没有uuid2()这个函数):
- uuid.uuid1([node[, clock_seq]]) : 基于时间戳;使用主机ID, 序列号, 和当前时间来生成UUID, 可保证全球范围的唯一性. 但由于使用该方法生成的UUID中包含有主机的网络地址, 因此可能危及隐私. 该函数有两个参数, 如果 node 参数未指定, 系统将会自动调用 getnode() 函数来获取主机的硬件地址. 如果 clock_seq 参数未指定系统会使用一个随机产生的14位序列号来代替.
- uuid.uuid3(namespace, name) : 基于名字的MD5散列值;通过计算命名空间和名字的MD5散列值来生成UUID, 可以保证同一命名空间中不同名字的唯一性和不同命名空间的唯一性, 但同一命名空间的同一名字生成的UUID相同.
- uuid.uuid4() : 基于随机数;通过随机数来生成UUID. 使用的是伪随机数有一定的重复概率.
- uuid.uuid5(namespace, name) : 基于名字的SHA-1散列值;通过计算命名空间和名字的SHA-1散列值来生成UUID, 算法与 uuid.uuid3() 相同.