bitcoin 交易锁定

交易的结构

Version
Txin[]
    prevout : txID + index
    sig 
    nSequence
Txout[]
    value 
    scriptPubkey
LockTime

bitcoin交易的锁定方法

bitcoin 交易提供了3种交易锁定的方式

  • 通过交易的LockTime 字段锁定交易
    • 通过该字段,用来锁定一个交易。
    • 如果该字段的值 小于LOCKTIME_THRESHOLD(500000000);则标识该交易的锁定高度
    • 如果该字段的值大于等于 LOCKTIME_THRESHOLD,则标识使用高度锁定。
  • 通过交易的nSequence 字段锁定某个指定的交易输入(使用BIP168进行检测)
    • 通过该字段用来锁住一个交易中的指定输入
  • 通过锁定脚本,锁定某个交易输出(添加了某个特殊的操作码)
    • 通过添加操作码,在锁定脚本上锁定一个交易的指定输出。

在交易进交易池,打包区块时,以及验证区块有效性时,都会判断交易的成熟度。对于未成熟的交易,不允许进入进入交易池,不允许打包。

详细解释

在交易池中,交易的输入分为两种:来自于UTXO的输出,来自于交易池中其它未确认交易的输出。

如果一个交易的所有输入都来自于UTXO:

如果要获取该交易所有输入 通过nSequence字段来标识的锁定时间戳;
第一步:是先判断该nSequence字段是否用来锁定

  • 如果某个交易输入的nSequence字段最高bit(1 << 31)位被设置,标识该字段没有启用锁定功能;否则启用了锁定功能

第二步:判断nSequence字段使用了哪种锁定功能

  • 如果第22bit位被设置,则标识启用了时间戳锁定的功能;否则标识启用了高度锁定的功能
    • 对于时间戳的锁定功能:该交易输入的锁定时间为,它的父区块的中位数时间戳 + 锁定字段的值* (1<< 9) - 1
    • 对于高度锁定功能:该交易输入的锁定高度为, 该输入的 utxo高度 + 锁定字段的值 - 1

第三步:依据这些依赖于 nSequence字段进行锁定的交易输入,记录他们的高度,并去除交易池中的交易输入,获取该交易剩下的 utxo集的最高的块索引,用来作为缓存,可以标识刚才计算的交易的锁定时间和锁定高度什么时候失效。

第四步:比较锁定的时间戳和锁定高度

  • 只有当这个交易所有输入的 最大锁定时间和最大锁定高度 大于当前Tip区块时,这个交易才被允许打包到下一个区块中。

对于交易池中的交易,它的输出形成的临时utxo 在集合中的高度为 MEMPOOL_HEIGHT(0x7FFFFFFF),在计算锁定时间和锁定高度时,它的高度被临时赋值为 Tip + 1;

则当交易池中某交易依赖于交易池中其他交易的输出

  • 且该输出还使用nSequence字段进行时间戳锁定时,它的锁定时间的计算相当于当前Tip区块的中位数时间 + 锁定字段的值 * (1 << 9) - 1;所以它肯定在当前正在打包的区块中成熟,所以不会在当前区块时被打包。
  • 该输出使用nSequence字段进行高度锁定,它的锁定高度相当于当前正在打包的区块高度 + 锁定字段的值 - 1

你可能感兴趣的:(bitcoin 交易锁定)