理解UTXO账户模型

什么是UTXO?浅谈比特币账户模型

  1:什么是UTXO?

  UTXO的英文全称为Unspent Transaction Output,汉语翻译过来则为:未消费的交易输出。我们可以把UTXO理解为交易过程中的一个数据结构。未花费的交易输出UTXO是一个包含交易数据和执行代码的数据结构,可以通俗的理解为某仓库(某地址)已经收到的但是尚未花费出去的加密数字货币。基于区块链的加密数字货币使用UTXO来验证一个人(其实是一个地址)是否拥有未使用过的加密数字货币用于支付。

  UTXO模型是中本聪在bitcoin模型中初创并引用的,因为我们谈到UTXO总会首先联想到比特币,但是需要额外指出的是:UTXO不是比特币独有的,当然 UTXO跟区块链也没有必然的联系,比如你可以模仿比特币但是不使用UTXO模型。

  PS: 有一些博文中将其解释为未消费的事务输出。

  个人认为不合理,比特币的流转过程是一个输入与输出的过程,我们知道比特币只是一个以区块链为底层技术的应用之一罢了,所以比特币本身践行着”价值“的传输(”价值“的传输模式 是为了区分现行互联网上的”数据“传输(字节复制),比如传输一个文件),这个价值转移的过程,其实就是交易的过程。

  说道这里,想解释一下TX的含义,通过上面的英文全称解析,我们知道TX代替的是Transiaction。但是为什么呢?

  原因1:在比特币社区里,大家习惯性的用TX来代替交易Transaction。

  比特币区块描述

  其中:TX代表的是Transaction,其中数字“44”代表的是本区块打包的交易笔数。

  PS1:关于区块结构及解析,将会在本专栏系列文章中进行详细解读,敬请期待。

  PS2:至于什么是加密数字货币浏览器? 什么是加密数字货币(什么是比特币)?将会在本专栏系列文章中进行详细解读,敬请期待。

  2:常规的账户余额系统与比特币的账户模型是什么?

  我们常规理解的账户余额系统是什么样子的?下面举一个转账的例子

  Case背景: TT 在某第三方中心化支付系统账户(比如招商银行的账户)上有存款1000元,ZY有2000元,TXT有3000元。

  操作如下:

  操作1:TT某天向ZY转账800元;操作2:ZY然后向TXT转账500元。

  假设平台手续费为0,那么在每一步操作,第三方支付账户系统需要做如下逻辑(以操作1举例说明):

  (1)判断TT账户余额是否足够800元,如果不够 ,操作失败,取消交易。如果足够则转向(2);

  (2)TT账户余额减少800,同时ZY账户余额增加500;这一步操作是事务性操作,可以理解为同成功,同失败。

  其中第(2)步,如果间隔有时差(现实中会有这种情况),那么就会出现常见的“双花问题”(也叫双重支付攻击,double spent attack)

  操作1结束,操作2类似,不详细描述,如下图所示

理解UTXO账户模型_第1张图片

  转账操作前初始状态

理解UTXO账户模型_第2张图片

  操作1转账之后余额状态

理解UTXO账户模型_第3张图片

  操作2转账之后余额状态

  (1)现在的银行支付系统、证券交易系统,包括互联网第三方支付系统(比如支付宝等),其核心都是基于账户(account based)的设计,底层数据都是由关系型数据库(RMDB:Relation Manage DataBase)支撑。

  (2)RMDB的好处是可以支持事务性操作,RMDB所具有的ACID特性(原子性,一致性,隔离性,持久性)。

  比特币的账户模型就是基于UTXO数据结构

  业内流行一句话:”其实并没有什么比特币,有的只是UTXO“---孟岩;个人表示赞同。

  在比特币交易中,每一笔交易都会有”交易输入”(即资产来源)和“交易输出”(即资产去向,当然比特币模型里叫做未花费的交易输出)。

  可以通俗的理解为:别人付给你的钱是“交易输入”,你收到的钱是“交易输出”。

  每一笔交易当中有可能有多个“交易输入”和多个“交易输出”。每一笔交易都是按照时间戳发生的顺序,使用固定编码编排的。

  而且,任何一笔“交易输入”都是前序某个交易当中产生的“未花费交易输出”,就像接链条一样,前后互相链接,前一个链条块的输出就是后一个链条块的输入。

理解UTXO账户模型_第4张图片

  一笔UTXO交易的组成

  一笔比特币交易的流程是什么样子呢?下面举一个例子来解释下:

  Case背景:TT的钱包(对应公钥地址A)里有12.5个比特币(其实就是UTXO),ZY钱包(对应公钥地址B)里拥有5个比特币,TXT钱包(对应公钥地址C)里有0个比特币。

  操作(1)TT给TXT支付一笔5个比特币;

  操作(2)TT又给TXT支付一笔2个比特币;

  操作(3)ZY给TXT支付一笔1个比特币;

  操作(4)TXT给其他某个人转出支付一笔3.5个比特币。

  那么,TXT的钱包里的比特币(UTXO)变化是什么样子呢?

  比特币变化结果如下:

  操作(1)之后,TXT钱包里有一笔大小为5的UTXO收入交易记录,共一笔,净UTXO:5;

  操作(2)之后,TXT钱包里有一笔大小为5的和一笔大小为2的UTXO收入交易记录,共两笔,净UTXO:7;

  操作(3)之后,TXT钱包里有一笔大小为5的,一笔大小为2的和一笔大小为1的UTXO收入交易记录,共三笔,净UTXO:8;

  Caution:

  操作(4)之后,TXT的钱包里基于(3)的基础上,新增一笔支出大小为5个UTXO,然后新增一笔大小为1.5的收入交易记录。净UTXO:3-->4.5(终态);

  为什么呢?

  原因是:UTXO模型中,交易处理的基本单位是一个交易记录,任何一个交易的输入都是某一个交易的输出。可以浅显的理解为:上述的三笔收入分别为1,2,5个大小的UTXO为三个面额为1,2,5的硬币,硬币的消费是不会掰开花的,只能拿出合适的一个全花出去,然后接受对方找零(其实不是对方找零,而且比特币交易系统自动为我们做的找零操作,UTXO接收方(目标地址)是感知不到的);

  总结一下,UTXO的三个原则

  1)所有交易始于coinbase(即始于挖矿奖励所得);

  2)除了coinbase交易之外,所有的交易输入都必须来自于前面一个或者几个交易的UTXO输出。

  3)每一笔的交易支出总额等于交易收入总额;

  UTXO与支付系统账户模型的区别是什么?

  1)在比特币系统中,没有账户的概念,所以也就没有余额的概念,有的只是UTXO,比特币交易系统中,用一连串的关联交易来计算,某地址(类比于账户系统中的账户概念)下究竟有多少UTXO,通过这个UTXO计算值来确定,一个地址是否具有转移出一笔交易的能力。

  2)区别

  在支付系统账户模型中,一个账户具有账户名(账户唯一ID)和密码,通过账户ID和密码认证,即获得了对该账户的使用权和支配权。也就是说,该账户内的所有资产归经过密码安全认证的人所有。

  在比特币交易系统中,没有账户iD和账户密码一说,也没有账户余额计算一说。但是 有公钥(钱包地址)和秘钥,可以浅显的类比理解为:公钥就是账户ID,私钥就是账户密码。在比特币交易系统中,知道对方公钥,就可以给对方转账进行交易。拥有了私钥,就代表着拥有了该地址下所有UTXO的使用权和控制权。

 

 

 

个人理解:UTXO账户模型中没有账户余额的概念,只有一条条的输入/输出记录,都是交易的记录,A给B转了5个比特币,就意味着本交易的输入是5,且来自A的账户地址,交易输出也是五,输出的交易地址B的账户地址

理解UTXO账户模型_第5张图片

1)001号交易为Coinbase交易,也就是挖矿交易,在这个交易中,“输入”部分没有对应的“输出”,而是由系统直接奖励发行比特币,矿工Alice得到了12.5个比特币的奖励,放在001号交易的“输出”部分。此时,对于Alice来说,拥有了这12.5个比特币的支配权,这12.5个比特币的输出可以作为下一笔交易的“输入”,顾名思义,这笔“输出”就称之为是Alice的未花费输出,也就是Alice的UTXO的意思。

2)002号交易中,Alice转账6比特币到Bob的地址,Alice找到了自己的UTXO(如果Alice不止一笔UTXO,可以根据一定的规则去选用,比如将小金额的先花费掉)。由于只需要转账6比特币,可是UTXO中却有12.5个,因此需要找零6.5个到自己的地址中,由此产生了002号中的交易输出,注意,在002号交易输出中的Alice地址是可以和001号中的Alice地址不一样的,只要都是属于Alice自己的钱包地址就可以。

3)003号交易中,Bob转账了2比特币到Lily的地址,过程与002号交易相同,就不再赘述了。

4)交易的输入使用的是上一个交易的输出

转载于:https://www.cnblogs.com/lingYaoYao/p/9270211.html

你可能感兴趣的:(理解UTXO账户模型)