比特币的可扩展性问题是其面临的主要问题之一,也是许多人努力的方向。比如说,有个设想是“闪电网络”;但是,要在比特币网络中实现闪电网络,条件似乎还不具备,因为比特币自身的一些缺陷。另一个解决方案“隔离见证”也致力于提高可扩展性,但它同时也解决了许多问题,包括闪电网络实现所需修补的一些缺陷。本文中我们会讲解隔离见证的优势及其工作原理。隔离见证是一个由多个BIP描述的软分叉,其主要用意是优化比特币交易和区块的结构,将交易的签名”、“witness”或“解锁脚本”)从交易中移到一个独立的结构中。它不仅允许降低比特币交易的数据量大小,也能解决“交易熔融性”问题,对支付通道和闪电网络这样基于比特币交易结构的技术来说极为关键。隔离见证如何工作
在开始之前
我们先要简单回顾一下比特币的支付系统。它并不像银行那样,是一套账户和余额的列表。相反,每个比特币地址的余额都是由一系列发送给这个地址的交易来表示的;交易这一数据结构的主要部分就是输入和输出。输入是我们想要花费的前序交易,而交易的输出就是我们的资金发送的目的地址。下图展示了比特币交易的结构:
SEC就Coinbase内幕交易对Wahi兄弟提起的诉讼达成和解:金色财经报道,美国证券交易委员会 (SEC) 于5月30日宣布,前Coinbase产品经理Ishan Wahi和他的兄弟Nikhil Wahi已同意就美国SEC对他们提出的内幕交易指控达成和解。[2023/5/31 11:48:52]
输出中的PubKeyScript字段就是我们所说的“锁定脚本”。它用来保证只有接受地址的所有者才能使用这个支出。SignatureScript字段也就是所谓的“解锁脚本”,因为它是用来打开锁定脚本的钥匙,是用来证明地址所有权的。有关比特币交易和锁定脚本、解锁脚本功能的更多细节,可看此处。后向兼容性
实际上,隔离见证不仅改变了交易的结构,也改变了交易的输出。不过,这不是说传统类型的UTXO和SegWit类型的UTXO无法在同一笔交易中花费:这种情况下,传统类型的UTXO将在输入内加载所有权证明,而隔离见证类型的UTXO将在交易输入以外的结构中加载证明。不管怎么说,隔离见证的定位是一个软分叉,这个升级应该是可以忽略,无需强制的,而且,这也意味着,未升级的节点应该可以处理隔离见证类型的输出。实际上,旧的节点和钱包将以为任何人都能花费这些UTXO,也即这些UTXO是空签名也可花费的,因此即使在交易中没有看到签名,交易也仍然是有效的。而升级后的节点和钱包将在交易输入以外的地方,一个专门的“witness”字段寻找签名。案例
Pay-to-Witness-Public-Key-Hash
我们用例子来说明一下隔离见证会如何改变交易的数据结构。从标准的Pay-to-Public-Key-Hash(P2PKH)交易类型开始。我们感兴趣的部分是输出,尤其是其“scriptPubKey”字段。我们先考虑一种标准的锁定脚本:
TrueUSD:部分美元资金存放在Signature Bank:金色财经报道,TrueUSD发推称,Signature Bank已被美国监管机构关闭,因此TrueCoin暂停对少数Signature Bank用户的TUSD铸造与赎回业务。TrueUSD银行网络中其他用户的铸币与赎回仍未受到影响。
此外,TrueUSD的部分法定货币美元资金存放在Signature Bank,该银行现在完全由美联储支持。目前,TrueUSD将直接与Signature Bank上的TUSD用户联系。[2023/3/13 13:00:25]
而隔离见证之后的锁定脚本如下所示:
如你所见,隔离见证的输出比传统类型的输出要简单很多:只有两个值会被推入脚本执行栈中。如我们上面说得,旧版本的比特币客户端会以为这个输出是掉在地上的钱——无需提供签名就能花费这个输出。不过,新的客户端会将第一个数字解释为版本号,而第二个则对应着一个锁定脚本。在现实中,只有压缩公钥的哈希值可以用在这里。这一点我们后面再说。再来看看这个输出被花费时的情形。传统交易的输出在花费时的数据结构如下:
Visa:新加坡消费者希望可以选择控制他们的数据:金色财经报道,根据 Visa 最近发布的消费者数据研究,随着新加坡消费者越来越多地在线生活,几乎十分之八 (77%) 的人希望可以选择控制他们的数据,而不是让公司和政府自行决定。该研究还发现,三分之二的新加坡消费者每周都会使用购物应用程序/网站和金融服务应用程序/网站,这使他们面临越来越多的个人数据请求。65% 的消费者几乎每次使用在线服务时都需要提供个人数据。然而,接近四分之三 (74%) 的新加坡消费者表示,公司很少就数据收集政策或数据管理选项对他们进行教育,超过一半 (52%) 的人认为数据政策是为了保护公司的合法利益而不是他们的自己的。[2023/1/9 11:01:24]
但是,在花费一个隔离见证输出的时候,交易的scriptSig将为空,而所有的签名都会放到一个专门的地方:
警告虽然传统的客户端可以处理隔离见证的交易,但他们自己没法花这些钱:旧型的钱包可能会尝试用空签名来花用一个隔离见证的输出,但这笔交易在现实中是无效的。这就意味着,发送者必须知道接受方的钱包支不支持隔离见证,这样才能为之创建合适类型的输出。由BIP143定义,隔离见证的输出应该用压缩公钥的哈希值来创建。如果你用的是传统类型的地址或者非压缩公钥的哈希值,这个输出将变得不可用。Pay-to-Witness-Script-Hash
另一个关键的交易类型是P2SH。它让交易可以发送给脚本的哈希值。要花费P2SH交易的输出,花费者需要提供一个脚本,其哈希值应该与UTXO中的脚本哈希值匹配,并基于这个脚本提供签名/口令/别的东西。这个用法可以把解锁脚本保护起来,让发送者无从知晓一个地址的内容,并且也能节约空间:举个例子,一个多签名钱包的锁定脚本可能非常长,这样我们就必须把整个锁保存起来;有了P2SH可以只保存一个哈希值。假设现在有一个需要提供5个私钥中的2个的签名才能使用的多签名钱包。如果你使用传统的交易,P2SH交易输出的锁定脚本将如下:
美国法官指示SEC遵守命令并出示在Ripple案中的文件:金色财经报道,美国地区法官驳回了美国证券交易委员会 (SEC) 在与区块链公司Ripple正在进行的案件中,试图从前公司财务部主任Bill Hinman那里屏蔽与2018年关于加密货币的演讲有关的文件。该委员会已对先前法官的决定提出上诉,要求其交出这些材料,作为其与加密支付公司的法律案件的一部分。自 2020 年美国证券交易委员会 (SEC) 对 Ripple 提起诉讼以来,大部分案件都集中在与 Hinman演讲相关的内部文件上。
Ripple继续要求提供与演讲相关的电子邮件和备忘录,地方法官Sarah Netburn多次站在Ripple 一边,否认SEC在2月和4月提出的重新审议请求。7月,美国证券交易委员会再次反对,将这个问题提交给地区法官Analisa Torres。Torres今天驳回了反对意见,指示美国证券交易委员会遵守命令并出示文件。[2022/10/1 22:43:33]
在P2SH中嵌入隔离见证
我们已经看到,使用隔离见证是有好处的。不过,上面的例子只对发送者和接收者都有升级软件的情形才适用。但现实并不总是如此。考虑这样一种情形:Alice希望给Bob转账一些btc,Bob有支持隔离见证的钱包软件而她没有。他们显然只能用标准形式的交易,但Bob希望使用SegWit来减少手续费。这时候,Bob可以创建一个包含了SegWit脚本的P2SH地址、Alice会把这个地址当成一个普通的P2SH地址,因此可以直接向这个地址转账而没有任何问题。但Bob可以使用SegWit交易来使用这个输出,并获得手续费折扣。这就是SegWit交易的两种类型P2WSH和P2WPKH在P2SH内实现的方式。P2SH(P2WPKH)
韩国SK集团电竞厂牌NFT将以盲盒形式发售:7月5日消息,韩国最大电信集团SK将推出电竞厂牌NICE,旨在寻找真正的电竞爱好者一起在元宇宙中打造最大的电子竞技品牌。多位电竞选手及战队已签约加入NICE,其中包括前FPX选手Khan,前OMG选手无状态cool等,未来将会有更多的职业选手以及电竞爱好者加入。
据悉,NICE发售首次采用MINT空投形式,将有1000枚其他已发售的蓝筹NFT发放给所有参与公售的用户,其中包括无聊猿BAYC#3264、BAYC#3947等。所有空投NFT均在其官网NICE.CLUB展示。SK集团旗下的电竞战队SKT在2013、2015、2016年英雄联盟赛事中均获得了总冠军。[2022/7/5 1:51:34]
想在P2SH交易中实现一笔P2WPKH交易,Bob需要使用其公钥创建一个见证程序。然后把结果哈希、转码成一个地址:
在一开始,我们创建的赎回脚本会经过一次哈希计算,如果结果符合锁定脚本中的哈希值,这个脚本就会得到执行,程序会验证放在witness字段的签名。P2SH(P2WSH)
P2WSH脚本也可以用P2SH来实现。我们考虑上面所说的2-5多签名钱包的例子。所有的步骤都跟P2SH(P2WPKH)没什么区别:首先,创建一个见证程序:
第一个数值是版本号,第二个数值是32位的SHA256哈希值,对应于我们的签名脚本。然后我们拿这个见证程序的HASH160哈希值转成一个普通的P2SH地址。要使用发往这个地址的输出时,我们需在scriptSig字段公布这个见证程序,在witeness字段提供完整的多签名脚本。隔离见证的好处
梳理清楚技术的部分之后,我们就可以理解隔离见证的主要优点了。交易熔融性漏洞
SegWit解决的一个关键问题就是比特币交易的“熔融性”,也即比特币交易的ID是哈希值这一点所带来的问题。我们详细说一下。在以往的比特币交易中,签名是放在交易的输入部分的,第三方可以更改签名且不会让交易失效。这使得第三方可以在完全不更改交易的“关键”字段的前提下更改交易的ID。这样一来,交易还是有效的,含义也还是一样的,但是有了另一个ID,这可以用来执行另一种攻击,比如DoS攻击。SegWit解决了这个问题,因为所有的签名都是放在交易外面的,因此签名的变动不会导致交易的哈希值变动,也就不会影响交易的ID。隔离见证还引入了一个专门的标识符,叫做“wtxid”:它是交易和整个witness部分的哈希值,所以如果一笔交易在传播时没有附带任何witness数据,交易ID就等于wtxid。这个解决方案使得我们可以创建一系列前后相继的未确认交易,而无需担心任何风险,这对闪电网络这样的协议来说是非常重要的。。网络和存储的扩展
Witness数据往往是交易数据中占比最大的一部分。在使用多签名脚本的交易中,witness最多可能占据交易数据量的75%。感谢SegWit,签名的传输变成了一个可选项:只有节点想要验证交易时,才需要请求这些数据。而没有支持SegWit的SPV客户端和节点也无需下载额外的数据,可以节省硬盘空间。可用的区块空间扩大,降低交易手续费
SegWit类型的交易比以往的交易类型更便宜,因为它减少了需要存储的witness数据。准确来说,“Size”的概念在SegWit类型的交易上略有不同。它引入了一个“虚拟大小”的概念:所有放在witness部分的数据都会乘以0.25来计算数据量大小,从而一个区块中可以塞进更多的交易。来看一个例子。假设我们有一笔传统类型的交易,数据量大小为200字节。那么1MB的区块里面可以放进5000笔这样的交易。而一笔等效的SigWit交易有120字节是放在witness区域的,因此其虚拟大小为80+0.25*120=110字节,所以区块可以放入9090笔这样的交易。如果上链的手续费是每字节40聪,则交易费会从8000聪减低到4400聪,几乎打了个对折。脚本版本
你可能已经注意到了,每个锁定脚本都会有1个字节来表示脚本的版本。使用不同的版本号就能以软分叉的形式增加或变更功能。签名验证的效率优化
隔离见证也优化了签名算法的效率。在SegWit之前,哈希计算的次数与签名数量的平方成正比,但有了隔离见证后,算法的计算复杂度就减低到了O(n)。
那还有啥问题呢?
如果百利而无一害,怎么还有人会觉得有问题呢?比特币社区有许多人反对这一升级,因为,即使它有这么多长处,它也有一些缺点。我们来看看反对方提出的一些意见。因为SegWit是一个软分叉,许多客户端可能不会升级,因此两种类型的UTXO会在网络中同时存在;诸如消除交易ID熔融性以及哈希计算次数线性上升这样的重大变更对非SegWit输出无效,因此网络仍会暴露在交易ID熔融性和哈希时间平方级上升的风险中。SegWit会降低网络的安全性,执行完全验证的节点会大幅减少,因为只有那些适配了SegWit的节点才有能力验证交易的witness部分。SegWit不能被废除。如果废除了它,所有变更都撤销,那么所有的SegWit输出就会变成大街上任人捡拾的钱。SegWit希望一次解决所有问题,也正因此,它导致了大量的代码改动。它会让未来的工作更加负载,而且提高了出现驱之不去的软件bug的机会。结论
虽然由SW解决的问题很有可能有更优雅的解决方案,我们仍然相信,在当前,这是提高网络的可扩展性并开启闪电网络等技术实现的最佳办法。更详细的分析我们放在下一篇文章。
参考文献
Lightningnetworkindepth,part1:paymentchannels“Masteringbitcoin”—AndreasM.AntonopoulosBitcoinCoreblogManysegwitresourcesGoodarticleabouttxnmalleability
我们正在组建SolanaNFT联盟以推动Solana朝着通用的合约标准迈进。Solana在2021年实现了惊人的用户增长,并成为去中心化计算的领先区块链之一。然而,为了持续增长,Solana生态中的项目必须拥有一个统一的合约标准.
1900/1/1 0:00:00OEC的启动,可以说「正当时」。延伸阅读:OEC(OEC)使用指南作为加密牛市的坚定信仰者,我们坚持认为,五月之后受政策等多因素影响下的短暂颓势,远称不上是熊市,至多只是一个「倒春寒」.
1900/1/1 0:00:008月18日凌晨,老牌NFT交易平台SuperRare宣布将发行代币RARE,用于治理新推出的SuperRareSpaces和SuperRareDAO.
1900/1/1 0:00:00此前德勤(Deloitte)的一项调查结果表明,传统资管公司拥抱数字资产已成寻常。昨天,另一个来自英国的调研机构再次验证这一结论:NickelDigital是一家数字资产对冲公司,由前高盛和摩根大通的投资者创办.
1900/1/1 0:00:00·比特币是加密货币世界的市场基准。自去年5月19日COVID疫情驱动的崩溃以来,加密货币市场出现了最严重的跌幅。BTC单日暴跌33%,一度跌至29,000美元的低点.
1900/1/1 0:00:00在华盛顿、华尔街和硅谷,搞清楚美国证券交易委员会(SEC)主席GaryGensler对加密货币的立场已经成了一场猜谜游戏。加密行业游说者收看他在国会的作证。律师们分析他的演讲.
1900/1/1 0:00:00