uuid
摘抄自: https://blog.csdn.net/u010700415/article/details/9122119 ,仅添加一些不熟悉的名词注解.
全拼
-
UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写
-
UUID是128位的全局唯一标识符,通常由32字节的字符串表示。
它可以保证时间和空间的唯一性,也称为GUID,全称为:
UUID —— Universally Unique IDentifier Python 中叫 UUID
GUID —— Globally Unique IDentifier C# 中叫 GUID
UUID主要有五个算法
-
它通过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的唯一性。
UUID主要有五个算法,也就是五种方法来实现:-
uuid1()——基于时间戳
由MAC地址、当前时间戳、随机数生成。可以保证全球范围内的唯一性, 但MAC的使用同时带来安全性问题,局域网中可以使用IP来代替MAC。
-
uuid2()——基于分布式计算环境DCE(Python中没有这个函数)
算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。 实际中很少用到该方法。
-
uuid3()——基于名字的MD5散列值
通过计算名字和命名空间的MD5散列值得到,保证了同一命名空间中不同名字的唯一性, 和不同命名空间的唯一性,但同一命名空间的同一名字生成相同的uuid。
-
uuid4()——基于随机数
由伪随机数得到,有一定的重复概率,该概率可以计算出来。
-
uuid5()——基于名字的SHA-1散列值
算法与uuid3相同,不同的是使用 Secure Hash Algorithm 1 算法
-
使用方面:
-
- 首先,Python中没有基于DCE的,所以uuid2可以忽略;
- 其次,uuid4存在概率性重复,由无映射性,最好不用;
- 再次,若在Global的分布式计算环境下,最好用uuid1;
- 最后,若有名字的唯一性要求,最好用uuid3或uuid5。
编码方法:
>-*- coding: utf-8 -*-
import uuid
name = "test_name"
print uuid.uuid1() # 带参的方法参见Python Doc
print uuid.uuid3(uuid.NAMESPACE_DNS, name)
print uuid.uuid4()
print uuid.uuid5(uuid.NAMESPACE_DNS, name)
一些生名词的注释
-
随机数和伪随机数
- 随机数: 就是你理解的随机数. 专业解释: 专门的随机实验的结果.
- 伪随机数: 就是算法算出来的. 伪随机数是用确定性的算法计算出来自[0,1]均匀分布的随机数序列
既然是算法算出来的,所以一定有规律,真正的随机数是没有规律的,
所以: 伪随机数发生器:其实计算机并不能产生随机数
-
MAC地址
- 理解: OSI模型第二层
- 定义: MAC地址(英语:Media Access Control Address),
直译为媒体存取控制位址,也称为局域网地址(LAN Address),MAC位址,以太网地址(Ethernet Address)或物理地址(Physical Address),它是一个用来确认网络设备位置的位址。在OSI模型中,第三层网络层负责IP地址,第二层数据链路层则负责MAC位址 [1] 。MAC地址用于在网络中唯一标示一个网卡,一台设备若有一或多个网卡,则每个网卡都需要并会有一个唯一的MAC地址 [2] 。
-
OSI模型
- 内容: OSI将计算机网络体系结构(architecture)划分为以下七层:
物理层: 将数据转换为可通过物理介质传送的电子信号 相当于邮局中的搬运工人。
数据链路层: 决定访问网络介质的方式。
在此层将数据分帧,并处理流控制。本层指定拓扑结构并提供硬件寻址,相当于邮局中的装拆箱工人。
网络层: 使用权数据路由经过大型网络 相当于邮局中的排序工人。
传输层: 提供终端到终端的可靠连接 相当于公司中跑邮局的送信职员。
会话层: 允许用户使用简单易记的名称建立连接 相当于公司中收寄信、写信封与拆信封的秘书。
表示层: 协商数据交换格式 相当公司中简报老板、替老板写信的助理。
应用层: 用户的应用程序和网络之间的接口。- 定义: 开放式系统互联通信参考模型(英语:Open System Interconnection Reference Model,缩写为 OSI),简称为OSI模型(OSI model),一种概念模型,由国际标准化组织提出,一个试图使各种计算机在世界范围内互连为网络的标准框架。