菜鸟学习状态通道,Part-1:支付通道
我的木头人亮
发表于 2022-11-30 23:23:08
176
0
0
7 b% Q9 V. r& A$ Q. k
-我坚持要放这张图上来——不过没法让它看起来攻击性弱一些。你们就原谅我吧。-
##支付通道5 x; |, z, s. o( D- R6 C4 ^2 }
那么,支付通道已经被讨论过一段时间了,可以在比特币闪电网络白皮书中找到很多关于其工作方式的参考。
如果你想寻找一个支付通道的现实世界中的例子,那就想象一下下面的场景:你经常在餐馆用餐,但只用支票付款(因为这对你来说是最方便的)——不过,无论何时兑现,银行都要收取餐馆 5 美元的费用。如果每张支票的平均金额为 15 美元,那就是 33.33% 的交易费。这样一来,我们该怎么办呢?7 K2 L) u4 H* b& Q8 y6 f1 L: O+ k
这种情况和你用支票付给餐馆的情况是一样的,只是你每开一张新支票时,都要把之前开给餐馆的支票额度累加,然后废掉之前开出的支票。这样餐馆就持有一张你所欠金额的总支票,因此餐馆能够通过银行一次性处理多笔交易,也降低了银行的交易费。这看起来有点像下面这张图:
-一个现实世界中支付通道的例子-
在上面的例子中,我们看到,可以通过替换新支票,对旧支票进行结算并作废,来减少交易费。
根据我的背景,我将从以太坊开发者的角度来解释它在区块链领域的工作原理。/ T: E; m9 ]& t1 S4 |* i
在创建支付通道时,双方都要同意将 ETH 存入一个智能合约中(在本例中,Alice 和 Bob 都投了 25ETH)。智能合约有接收多签名交易的能力,并能给双方支付相应的金额。如果双方都签名了最新的离线交易(在本例中 Alice 15ETH,Bob 35ETH),并将最新交易发给智能合约,智能合约就会实时更新并向双方支付。
与每个签名交易有关的 Nonce 是为了进行交易排序的。假设 Alice (向合约)提交了一个交易,Nonce 值为0,但是 Bob 不同意这笔交易,因为两人之间已经发生了一笔更新的交易。因此,如果双方都不同意提交到智能合约的交易,智能合约就会等一段时间(这个就叫挑战期)来等待一笔新交易(或者有一个更高 Nonce 值的交易到来)。每当人们给合约发送一笔交易,合约都会相应开始一段挑战期,等待更新的交易到来。如果没有新交易提交,并且等待期已过,那么智能合约就会立即执行更新,并根据最新交易对双方进行支付。下面有一个例子,说明这种情景是如何发生的:; F {4 ` p3 e# a+ J
" a7 t* s" U+ ~* @ J' H* j
Alice 想提交一笔旧的交易-& X/ P- B1 `/ ^% p4 ~6 W6 R
Bob 提交了一笔最新的交易-4 m2 V8 ^& d% F! n
; j* R, J% f/ R# c( O, l
-智能合约会在挑战期结束后进行支付-
所以,支付通道的主要好处包含:隐私——在一组完整的交易中,公众只知道链上登载的最后结果;因此,Alice 和 Bob 的隐私在交易过程中是受到保护的即时生效——Alice 和 Bob 可以立即签署和交换消息,不需要等链上的状态确认——从而获得更好的用户体验。更低的交易费——Alice 和 Bob 能自由地交换ETH,只需为创建通道和 结算/关闭通道 的链上交易付出手续费即可。
这里要注意的一点是,为了确保发送到链上的交易已经得到了通道各方的同意,每个支付通道在创建时必须有一组定义好的用户。
) J$ ]! v4 x# C4 t `" |, Z1 N2 d
Part-2:App-Specific State Channels
在我的下一篇博文中,我将深入研究APP特有的状态通道。0 D" S7 O9 d0 h, J7 Z) S
如果你在开发利用状态通道的项目,我非常希望看到你的实现以及你开发的方式。如果有什么我可以改进的地方,请在评论部分告诉我。我只不过是个社交媒体的新手。最后,如果你从这篇文章中学到了一些东西,非常感谢你把这个分享到你的社交网络里。
成为第一个吐槽的人