美文网首页
bitcoin 交易锁定

bitcoin 交易锁定

作者: 路之遥_其漫漫_ | 来源:发表于2018-09-30 10:29 被阅读0次

    交易的结构

    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 交易锁定

          本文链接:https://www.haomeiwen.com/subject/mfqdnftx.html