当我们在做订单号的时候,可以发现我们使用订单号有个硬性条件,就是它最好的唯一性的,且最好是自增长。
在我们python中,系统自带了一个唯一的模块,就是uuid。但是我们使用uuid来生成订单号虽然也能使用,但是却有一个致命的缺点,就是无序。
关于UUID(univeral unique identifier)
uuid是128位的全局唯一标识符(univeral unique identifier),通常用32位的一个字符串的形式来表现。python中自带了uuid模块来进行uuid的生成和管理工作。在python中的uuid模块是基于MAC地址、时间戳、命名空间、随机数、伪随机数来生成的。
uuid.uuid1()基于MAC地址,时间戳,随机数来生成唯一的uuid,可以保证全球范围内的唯一性。
1 | import uuid |
uuid.uuid2()算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。不过需要注意的是python中没有基于DCE的算法,所以python的uuid模块中没有uuid2这个方法。
uuid.uuid3()通过计算一个命名空间和名字的md5散列值来给出一个uuid,所以可以保证命名空间中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。
namespace并不是一个自己手动指定的字符串或其他量,而是在uuid模块中本身给出的一些值。比如uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_OID这些值。这些值本身也是UUID对象,根据一定的规则计算得出。
1 | import uuid |
通过伪随机数得到uuid,是有一定概率重复的
1 | import uuid |
和uuid3基本相同,只不过采用的散列算法是sha1
1 | import uuid |