UUID
1.UUID是谁?从哪里来?要到哪里去?
uuid是个ID,我们知道ID是不能重复的。在个人作品的小范围内可以保证ID不重复,但是一件全球化产品的ID值怎么保证不重复呢?uuid(universally unique )全球通用唯一ID,就为解决这一问题因运而生。
uuid是谁搞明白了,那它是怎么来的呢?uuid=当前时间+时钟序列+本机Mac地址。Mac地址保证了你的ID和别人的不会重复。当前时间保证了你的ID不会和自己的重复,所以就是唯一的ID。有关组织规定其长度为128bit,为了提高效率,常用32位的字符串。
uuid要到哪里去?也就是其应用为何呢?答案就是省略了用中央控制端来指定辨识资质的繁琐步骤,改用通用唯一的ID,比如建立数据库时很好的解决了名称重复的问题。在此基础上uuid有多个版本,常用的有基于时间的,基于名字的,DEC安全的和随机的uuid四种版本。
2.认识python中的uuid库
python标准库中带有uuid模块来进行uuid的生成和管理工作。python中的uuid模块基于信息如MAC地址、时间戳、命名空间、随机数、伪随机数
(使用一定算法产生的0到1之间分布均匀的随机数,不是真正意义上的随机数)来生成uuid。具体方法有如下几个:
uuid.uuid1() 基于MAC地址,时间戳,随机数来生成唯一的uuid,可以保证全球范围内的唯一性。
uuid.uuid2() 算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。不过需要注意的是python中没有基于DCE的算法,所以python的uuid模块中没有uuid2这个方法。
uuid.uuid3(namespace,name) 通过计算一个命名空间和名字的md5散列值来给出一个uuid,所以可以保证命名空间中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。namespace并不是一个自己手动指定的字符串或其他量,而是在uuid模块中本身给出的一些值。比如uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_URL,uuid.NAMESPACE_X500。这些值本身也是UUID对象,根据一定的规则计算得出。
uuid.uuid4() 通过伪随机数得到uuid,是有一定概率重复的
uuid.uuid5(namespace,name) 和uuid3基本相同,只不过采用的散列算法是sha1。
uuid(1)绝对唯一,但是有可能会泄露计算机的MAC地址。uuid(4)是随机的,不能保证不会发生碰撞。但是几率非常非常小。uuid(3)和uuid(5)都采用空间命名的方式,只不过加密的散列方式不同。下面来贴出实例: