Python使用UUID庫生成唯一ID

資料:    Python官方Doc:《20.15. uuid — UUID objects according to RFC 4122》
    UUID的算法介紹:《A Universally Unique IDentifier (UUID) URN Namespace》概述:    UUID是128位的全局唯一標識符,通常由32字節的字符串表示。
    它可以保證時間和空間的唯一性,也稱爲GUID,全稱爲:
            UUID —— Universally Unique IDentifier      Python 中叫 UUID
            GUID —— Globally Unique IDentifier          C#  中叫 GUID

    它通過MAC地址、時間戳、命名空間、隨機數、僞隨機數來保證生成ID的唯一性。
    UUID主要有五個算法,也就是五種方法來實現:

       1、uuid1()——基於時間戳

               由MAC地址、當前時間戳、隨機數生成。可以保證全球範圍內的唯一性,
               但MAC的使用同時帶來安全性問題,局域網中可以使用IP來代替MAC。

       2、uuid2()——基於分佈式計算環境DCE(Python中沒有這個函數)

                算法與uuid1相同,不同的是把時間戳的前4位置換爲POSIX的UID。
                實際中很少用到該方法。

      3、uuid3()——基於名字的MD5散列值

                通過計算名字和命名空間的MD5散列值得到,保證了同一命名空間中不同名字的唯一性,
                和不同命名空間的唯一性,但同一命名空間的同一名字生成相同的uuid。    

       4、uuid4()——基於隨機數

                由僞隨機數得到,有一定的重複概率,該概率可以計算出來。

       5、uuid5()——基於名字的SHA-1散列值

                算法與uuid3相同,不同的是使用 Secure Hash Algorithm 1 算法

使用方面:

    首先,Python中沒有基於DCE的,所以uuid2可以忽略;
    其次,uuid4存在概率性重複,由無映射性,最好不用;
    再次,若在Global的分佈式計算環境下,最好用uuid1;
    最後,若有名字的唯一性要求,最好用uuid3或uuid5。

編碼方法:

    # -*- coding: utf-8 -*-

    import uuid

    name = "test_name"
    namespace = "test_namespace"

    print uuid.uuid1()  # 帶參的方法參見Python Doc
    print uuid.uuid3(namespace, name)
    print uuid.uuid4()
    print uuid.uuid5(namespace, name)


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章