uuid在哪里(UUID是怎么来的)(1)

定义

Universally Unique Identifier:通用唯一识别码。一种软件建构的标准,亦为开放软件基金会组织在分布式计算环境领域的一部分。

目的

让分布式系统中的所有元素,都能有唯一的辨识信息,而不需要通过中央控制端来做辨识信息的指定。如此一来,每个人都可以创建不与其它人冲突的UUID。

示例

public static void main(String[] args) { String uuid = UUID.randomUUID().toString(); System.out.println(uuid); System.out.println(uuid.length()); uuid = uuid.replace("-",""); System.out.println(uuid); System.out.println(uuid.length()); }

原理

参考 远程服务调用 | 凤凰架构#三个基本问题

所有流行过的 RPC 协议,都不外乎变着花样使用各种手段来解决以下三个基本问题:

如何表示数据:

这里数据包括了传递给方法的参数,以及方法执行后的返回值。无论是将参数传递给另外一个进程,还是从另外一个进程中取回执行结果,都涉及到它们应该如何表示。(序列化与反序列化)

如何传递数据:

准确地说,是指如何通过网络,在两个服务的 Endpoint 之间相互操作、交换数据。(Wire_Protocol)

如何确定方法:

每门语言的方法签名都可能有所差别,所以“如何表示同一个方法”,“如何找到对应的方法”还是得弄个跨语言的统一的标准才行。这个标准做起来可以非常简单,譬如直接给程序的每个方法都规定一个唯一的、在任何机器上都绝不重复的编号,调用时压根不管它什么方法签名是如何定义的,直接传这个编号就能找到对应的方法。这种听起既粗鲁又寒碜的办法,还真的就是 DCE/RPC 当初准备的解决方案。

虽然最终 DCE 还是弄出了一套语言无关的接口描述语言 (Interface Description Language,IDL),成为此后许多 RPC 参考或依赖的基础(如 CORBA 的 OMG IDL),但那个唯一的绝不重复的编码方案UUID (Universally Unique Identifier)却也被保留且广为流传开来,今天已广泛应用于程序开发的方方面面。

,