python3_UUID模塊詳解
1、知識背景
UUID是128位的全局唯一標識符,通常有32字節的字母表示。它可以保證時間和空間的唯一性。
UUID——Universally unique identifier 在python中叫UUID,在C#中成為GUID(globally unique identifier)
它通過mac地址,時間戳,命名空間,隨機數,偽隨機數來保證生成ID的唯一性。
2、為什麽要使用UUID?
很多應用場景需要一個id, 但是又不要求這個id 有具體的意義, 僅僅用來標識一個對象. 常見的例子有數據庫表的id 字段. 另一個例子是前端的各種UI庫, 因為它們通常需要動態創建各種UI元素, 這些元素需要唯一的id , 這時候就需要使用UUID了.
3、python3的UUID模塊:該模塊提供不可變的UUID對象(UUID類)和函數uuid1(),uuid3(),uuid4(),uuid5()來生成1,3,4,5各個版本的UUID(python中沒有uuid2這個函數)。
UUID模塊中最常用的幾個方法總結如下:
uuid1()——基於時間戳
uuid.uuid1([node[, clock_seq]])
使用主機ID,序列號,和當前時間來生成UUID,可保證全球範圍的唯一性,當由於該方法生成的UUID中含有主機的網絡地址,因此可能危機隱私。該函數的node參數為指定,系統會自動調用getnode()函數來獲取主機的硬件地址。如果參數clock_seq未指定,系統會使用一個隨機產生的14位序列號來代替。
uuid3()——基於名字和MD5散列值
uuid.uuid3(namespace, name)
通過計算命名空間和名字的MD5散列值來生成UUID,可以保證同一命名空間中不同名字的唯一性和不同命名空間的唯一性,同一命名空間的同一名字生成的UUID相同。
uuid4()——基於隨機數
uuid.uuid4()
通過隨機數來生成UUID,使用的是偽隨機數,有一定的重復概率
uuid5()——基於名字的SHA-1散列值
uuid.uuid5(namespace, name)
通過計算命名空間和名字的SHA-1散列值來生成UUID,算法與uuid.uuid3()相同。
示例代碼
importuuid print(uuid.uuid1()) print(uuid.uuid3(uuid.NAMESPACE_DNS, ‘testme‘)) print(uuid.uuid4()) print(uuid.uuid5(uuid.NAMESPACE_DNS, ‘testme‘)) x = uuid.UUID(‘{00010203-0405-0607-0809-0a0b0c0d0e0f}‘) print(str(x))
運行結果(xxx是手動更改的):
/usr/bin/python3.5 /home/rxf/python3_1000/1000/python3_server/python3_uuid/demo1.py xxxx-c456-11e7-923c-xxxxxx xxxx-50fd-36f7-bbeb-1c739ab40b8c xxxxx-258a-4207-b52d-b01b1cec0985 xxxxx-a443-578c-8754-856842a2f98d 00010203-0405-0607-0809-0a0b0c0d0e0f
Process finished with exit code 0
看見有前輩使用方面的建議: 首先,Python中沒有基於DCE的,所以uuid2可以忽略; 其次,uuid4存在概率性重復,由無映射性,最好不用; 再次,若在Global的分布式計算環境下,最好用uuid1; 最後,若有名字的唯一性要求,最好用uuid3或uuid5。
參考:
UUID算法:https://tools.ietf.org/html/rfc4122.html
Python_uuid模塊參考手冊:https://docs.python.org/3/library/uuid.html
python3_UUID模塊詳解