UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写,其目的,是让分布式系统中的所有元素,都能有唯一的辨识信息,而不需要通过中央控制端来做辨识信息的指定。
如此一来,每个人都可以创建不与其它人冲突的UUID。在这样的情况下,就不需考虑数据库创建时的名称重复问题。目前最广泛应用的UUID,是微软公司的全局唯一标识符(GUID)
1.简介
UUID 是国际标准化组织(ISO-International Organization for Standardization)提出的一个概念。UUID 是一个128比特的数值,这个数值可以通过一定的算法计算出来。
- UUID是指在一台机器上生成的数字,它保证对在同一时空中的所有机器都是唯一的。
UUID 由以下几部分的组合:
- 当前日期和时间,UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同。
- 时钟序列。
- 全局唯一的IEEE机器识别号,如果有网卡,从网卡MAC地址获得,没有网卡以其他方式获得。
2.重复机率
随机产生的 UUID 的128个比特中,有122个比特是随机产生,4个比特在此版本被使用,还有2个在其变体中被使用。
与被陨石击中的机率比较的话,已知一个人每年被陨石击中的机率估计为170亿分之1,也就是说机率大约是0.00000000006 (6 x 10^-11),等同于在一年内置立数十兆笔GUID并发生一次重复。换句话说,每秒产生10亿笔UUID,100年后只产生一次重复的机率是50%。如果地球上每个人都各有6亿笔GUID,发生一次重复的机率是50%。
3.版本
UUID具有多个版本,每个版本的算法不同,应用范围也不同。
基于时间的UUID
基于时间的UUID通过计算当前时间戳、随机数和机器MAC地址得到。
基于名字的UUID(MD5)
基于名字的UUID通过计算名字和名字空间的MD5散列值得到。这个版本的UUID保证了:相同名字空间中不同名字生成的UUID的唯一性;不同名字空间中的UUID的唯一性;相同名字空间中相同名字的UUID重复生成是相同的。