在本文中,我们将研究比特币的费用结构,并了解为什么比特币费用有时便宜,而有时却非常昂贵。中本聪在比特币的设计上花了很多心思,并且非常有目的地创造了交易费用。
-----------------------------------------------------------------------------------------------
比特币的交易费用激励矿工验证您的交易
当比特币的价格走势看涨或看跌时,自然会有更多人开始使用比特币。交易者买入或卖出,弱手恐慌,囤积者试图增持,购物者和商家利用购买力的增加/减少。
无论他们是使用比特币进行购买并利用 BTC 不断上涨的价格,进行交易以对期货进行投机性押注,还是只是试图为 Hodl 存储积累更多 BTC,网络活动的增加通常会导致交易费用的显着增加。
比特币将安全性置于效率之上,并且由于这种优先级权衡,每秒只能处理大约 4-7 笔链上交易。这种极其有限的吞吐量使得扩展比特币网络以进行大规模采用成为这种新金融技术面临的最大挑战之一。
由于比特币矿工可以选择将哪些交易包含在他们开采的区块中,并且交易是由矿工根据网络费用的自由市场系统选择的,因此矿工被激励将支付最高费用的交易包含在内,从而获得更高的收入.
因此,有时,在比特币网络使用量增加的时候,费用较低的交易会陷入内存池的边缘。内存池是未经确认的交易等待矿工验证的地方。
一旦矿工验证了交易,它就会得到第一次确认,离开内存池并被包含在一个区块中。随着新区块被添加到额外节点的分类账中,并且更多的新区块被依次添加,更多的确认会在区块链中僵化交易。
矿工通常只是简单地跳过费用较低的交易,并选择在网络拥堵和交易积压期间,将选择支付更多费用的交易纳入下一个区块。
我这样解释一下,如果我想向你发送 BTC 付款,平均网络费用是每字节 1 Satoshi,如果我每字节支付 2 Satoshi,我的交易将在与每字节 1 Sat 的较低费用,因为与当时的平均费用相比,包含它的矿工将获得双倍的费用支付。
矿工因贪婪而保持诚实,他们从费用和区块奖励中赚钱,并被激励为自己的最佳利益行事。这是中本聪为比特币网络设计的博弈论元素的一部分,以保护它免受攻击者的侵害。
在上一次牛市期间,以交易费的形式感受到了比特币的成长之痛
当情况导致网络使用水平增加时,随着用户争夺区块空间,费用也会随之上涨。没有足够高费用的交易,在平均网络费用下降到足够低以激励矿工将交易包含在他们的下一个区块之前,根本不会被确认。
这可能非常令人沮丧,而且成本也很高。 2017 年 12 月,当比特币达到历史最高点时,费用变得太高,无法证明进行小额购买是合理的,因为费用比购买的物品更昂贵。
许多比特币服务和企业最初没有将费用上涨的可能性考虑到他们的商业模式中,变得无利可图或无法使用,并因费用上涨而瘫痪。
从那时起,比特币进行了几项改进,有助于在拥塞和对区块空间的高需求期间降低费用,尽管它们都不是完美的解决方案。
最值得注意的是隔离见证(segwit),它修复了一个交易延展性错误,这是使闪电网络成为比特币之上的第 2 层功能可行的必要条件。
隔离见证为闪电网络铺平了道路,闪电网络是比特币近乎即时、廉价的去中心化支付系统,它使小额支付成为可能,并通过将大部分经济活动推向链外来缓解比特币的网络拥堵。
闪电网络目前是比特币的主要扩展解决方案,但仍处于早期阶段,开发人员仍在努力改进用户体验,使其对日常用户易于访问和实用。
在这方面取得了一些重大进展,许多比特币用户现在经常使用 LN,企业接受 LN 付款是很常见的。随着更多人加入 LN,随着更多支付渠道提高网络的整体可用性和容量,用户体验也将得到改善。
使用 LN,用户仍需支付交易费用,尽管与比特币的链上网络费用相比,这些费用微乎其微。 除了 LN 之外,还有其他扩展解决方案正在研究中,例如 Statechains、Sidechains、Drivechains、Chaumian 电子现金服务器和其他正在探索的提案。
这些解决方案中的每一个都有不同的费用、权衡、好处和限制。 随着比特币采用的增长,允许用户选择他们想要如何发送他们的 BTC、什么权衡是可以接受的以及他们想要支付什么样的费用的扩展解决方案将变得更加普遍。
感谢您使用 Bitrefill!
使用 LN,用户仍需支付交易费用,尽管与比特币的链上网络费用相比,这些费用微乎其微。 除了 LN 之外,还有其他扩展解决方案正在研究中,例如 Statechains、Sidechains、Drivechains、Chaumian 电子现金服务器和其他正在探索的提案。
这些解决方案中的每一个都有不同的费用、权衡、好处和限制。 随着比特币采用的增长,允许用户选择他们想要如何发送他们的 BTC、什么权衡是可以接受的以及他们想要支付什么样的费用的扩展解决方案将变得更加普遍。
感谢您使用 Bitrefill!