thomas_fahrer on Nostr: A few months ago Bitcoin core 24.0 was released and this release came with a lot of ...
A few months ago Bitcoin core 24.0 was released and this release came with a lot of controversy. In fact even today, there is pressure to roll back the changes made in this release .
So what was the issue?
The core feature of the release was a change affecting some big industry players, the network's scalability and security.
I'm talking about the mempoolfullrbf configuration option.
Here’s a simple breakdown.
Mempoolfullrbf refers to:
The Bitcoin Memory pool which is the 'waiting room' for all unconfirmed transactions on the Bitcoin network.
And RBF stands for Replace-by-Fee a mempool policy that allows nodes to decide between conflicting unconfirmed transactions based on feerate.
Prior to RBF, the mempool accepted whichever transaction it saw first.
In 2016 with the introduction of BIP 125 Bitcoin Core has used what's referred to opt-in - RBF. Where transactions in the mempool can be replaced IF they signaled they were replaceable i.e. they opted in.
This release introduces Full-RBF which allows full replacement of any transaction as distinct from only replacing transactions that opt-in to it.
Why is this controversial?
There are industry players using zero-confirmation transactions in their applications. To put it another way - they're accepting payments which are sitting in the mempool.
This is something which everyone knows is theoretically dangerous but hasn't been an issue because once the bitcoin network has fully propagated a non-replace-by-fee transaction, you need the collaboration of a miner to replace it, which isn't easy to get today.
Even though many of the biggest miners offer off-band transaction broadcasting services, they currently won't process conflicting transactions (double spends)
With the introduction of Full RBF these zero confirmation transactions are simply too risky. The chances of facing a double spend have gone up significantly *IF* you're someone who's accepting 0-conf transactions.
So why did protocol developers push forward with this change?
The point of Bitcoin blocks and proof of work is to solve double-spending.
When a miner receives two conflicting transactions the highest security policy is to have them take the higher fee. An assumption that miners are rational is better than assuming miners are nice.
Unfortunately while scaling Bitcoin through zero-confirmation transactions looks tempting. The reality is it's not possible to do so without damaging security and that's why we have the lightning network.
So what was the issue?
The core feature of the release was a change affecting some big industry players, the network's scalability and security.
I'm talking about the mempoolfullrbf configuration option.
Here’s a simple breakdown.
Mempoolfullrbf refers to:
The Bitcoin Memory pool which is the 'waiting room' for all unconfirmed transactions on the Bitcoin network.
And RBF stands for Replace-by-Fee a mempool policy that allows nodes to decide between conflicting unconfirmed transactions based on feerate.
Prior to RBF, the mempool accepted whichever transaction it saw first.
In 2016 with the introduction of BIP 125 Bitcoin Core has used what's referred to opt-in - RBF. Where transactions in the mempool can be replaced IF they signaled they were replaceable i.e. they opted in.
This release introduces Full-RBF which allows full replacement of any transaction as distinct from only replacing transactions that opt-in to it.
Why is this controversial?
There are industry players using zero-confirmation transactions in their applications. To put it another way - they're accepting payments which are sitting in the mempool.
This is something which everyone knows is theoretically dangerous but hasn't been an issue because once the bitcoin network has fully propagated a non-replace-by-fee transaction, you need the collaboration of a miner to replace it, which isn't easy to get today.
Even though many of the biggest miners offer off-band transaction broadcasting services, they currently won't process conflicting transactions (double spends)
With the introduction of Full RBF these zero confirmation transactions are simply too risky. The chances of facing a double spend have gone up significantly *IF* you're someone who's accepting 0-conf transactions.
So why did protocol developers push forward with this change?
The point of Bitcoin blocks and proof of work is to solve double-spending.
When a miner receives two conflicting transactions the highest security policy is to have them take the higher fee. An assumption that miners are rational is better than assuming miners are nice.
Unfortunately while scaling Bitcoin through zero-confirmation transactions looks tempting. The reality is it's not possible to do so without damaging security and that's why we have the lightning network.