pull down to refresh

Mining pools can exclude transactions if they want to

You may have heard rumblings that some pools are not including OFAC-sanctioned transactions in the blocks they are building. Recently, @0xB10C wrote a very thorough analysis of 15 transactions that were not included in blocks when, based on fee rates, we might have expected them to be. While b10c did not conclude that all 15 transactions were censored, it seems likely that at least one pool (F2Pool) was specificaly excluding OFAC-sanctioned transactions.
This isn't the first time F2Pool has done this. Indeed, the pool founder said they "have every right" to "refuse to confirm transactions for those criminals."
He's right: mining pools can exclude whichever transactions they want from the blocks they build.

Mining pool centralization

While we're at it, let's talk about another worrying trend in mining: mining pool centralization. Here's a chart of the blocks over the last week and which pool mined them:
In the past there have been mining pools representing larger fractions of the total hashrate, but the current situation certainly isn't something to be happy about, especially if pools find it convenient to work together.
Speaking of working together, perhaps you remember another article 0xB10C wrote about how a number of pools seemed to be using the same template as AntPool.
Consolidation of mining pool rewards also seems to indicate centralization among mining pools. @mononautical pointed out that at least 9 pools were using the same custodian for their coinbase transactions.
Of course, just as it's up to a pool to decide which transactions they mine, it's up to a hasher to decide which pool they work with.

The "Hope hashers are nice to us" security model

So, we have two problems:
  1. Mining pools are following government orders to exclude transactions from blocks.
  2. Mining pools seem to be consolidating.
Put together, you might wonder what would happen if a mining pool (or group of pools) that censors gets more than 51% of the hash power.
More than just excluding transactions from their own blocks, would they refuse to build on top of blocks that included OFAC-sanctioned transactions?
Another way to phrase the last part of this question is to say that the big CensorPool reorgs the chain1 any time another miner produces a block that includes transactions the CensorPool wants to censor. CensorPool only has this ability as long as they maintain majority hashpower. So, usually, people answer the question by saying if such a horrible thing happened, hashrate would leave the big, censoring pool and go to other pools that weren't so big and didn't censor.
However, we have to assume that hashers were pointing their hash at the big pool because it made the most sense for them. If our pretend CensorPool is only excluding a few transactions here and there, do we really think that enough hashers will leave the pool to make a difference? Especially in the case where it is clear that CensorPool has majority hashpower and defecting hashers only reap a benefit if they break the majority.
It seems likely that in doing so hashers would be incurring some loss of profit (at least because of switching costs, but likely also due to payout structure or pool size, as well as the increased risk that not enough hashers defect to break CensorPool's majority) and switiching is definitely not in their immediate best interest -- possibly not in their interest at all.
Does Bitcoin's security model in this situation rely on nothing more than the altruistic feelings of hashers? Hoping that hashers will do "the right thing" even when it's contrary to their immediate best interest?

The "Richie Rich" security model

But we have missed a vital piece of this puzzle. Those sad little OFAC-sanctioned transactions are still sitting there, feeling like nobody wants to play with them. So sad!
If your transaction isn't getting confirmed, what do you do? You offer to pay more to get it mined.
A pool like F2Pool can refuse to include any transaction they like, but if they don't maximize revenue, their payouts will not be as good as the payouts of the pools that do include such higher-fee-rate transactions.
Once mempools begin to fill up with high-fee-rate transactions, we don't have to rely on the altruistic feelings of hashers anymore; the chance to mine extra-juicy censored transactions definitely makes it in a hasher's interest to switch to a non-censoring pool.

Censors fix this

Imagine the worst case scenario from up above: a mining pool or consortium of pools controls more than 51% of the hashrate and excludes OFAC-sanctioned transactions from their blocks and they refuse to build on blocks that contain such transactions.
In theory, here's how it plays out:
  • at first, the transactions might simply sit in mempools.
  • When it's obvious they aren't getting mined, their owners might try increasing the fee-rate of their transactions.
  • Perhaps a minority hashpower mining pool sees some of these higher-fee rate transactions and tries to mine them, but their block is pretty quickly turned into a stale block by CensorPool reorging it.
  • The high-fee-rate transactions really begin to pile up. If enough transactions with high enough fee-rates are just waiting in mempools for everyone to see, the incentive for CensorPool hashers who want to make more money becomes stronger, perhaps strong enough to induce a chunk of them to break away from CensorPool.
And voila!: in yet another brilliant stroke of genius, Satoshi not only created a system where censorship produces the conditions for its own undoing -- but also simultaneously creates one of the few decentralizing pressures in mining. Any time a mining pool tries to exclude certain kinds of transactions it necessarily produces an incentive for hashrate to leave the pool.
If we end up with big pools, let's hope they try to censor! Because if they don't, the only defense we have against miner centralization is hoping that hashers "do the right thing."

A flaw in the brilliance

Unfortunately, there is a flaw here: there were only 165 OFAC-sanctioned transactions in 2024, and 378 such transactions in 2023.2 If such a scenario were to play out today, I'm not sure there is enough passed-over fee revenue to incentvize anyone attempting something like breaking away from a pool with dominant hash power.
For hashers to try to split away from a pool or group of pools with 51% or more of the hashpower, they would need to be pretty confident that the big pool wasn't going to be able to reorg them. The bigger the pot of fees to be gleaned from censored transactions, the stronger such decentralizing pressure becomes.3

Footnotes

  1. In the case where CensorPool has a strong majority of hashpower, this may just look like an increased number of stale blocks; however, it's not like nodes typically keep track of when the abandon a block for a longer chain, and to my knowledge there is no easy way to make sure we actually notice all the stale blocks that occur. Luckily, there are more obvious tells:there would be a marked increase in transactions that were not making it into blocks even though we might expect them to. In the case of the 15 transactions that 0xBC10 looked at, all of them made it into the next block.
  2. Once again, @0xBC10 is a huge resource on this. They maintain a list of OFAC sanctioned bitcoin addresses so you don't have to download the list yourself and sort it for Bitcoin addresses.
  3. As a side note, it's interesting to think about how mempool filtering (trying to censor transactions at the mempool and relay policy level) fails to produce this same result -- mostly because it just isn't very effective. Even if 70% of listening nodes censor your transaction and refuse to relay it, you still have a 95% chance that at least one of your outbound peers accepts and passses it on. For a censor to effectively censor transactions at the relay level, they would need to be running a vast majority of the nodes on the network. And even in that situation, miners interested in mining such transactions could always advertise a means of direct submission (email, webform, etc...). If there are miners who want to mine the transactions, it's very difficult to stop them from learning about them. If you have 51% of the hashpower though, it becomes a more realistic project to prevent their inclusion in a block.
It seems likely that in doing so hashers would be incurring some loss of profit (at least because of switching costs, but likely also due to payout structure or pool size, as well as the increased risk that not enough hashers defect to break CensorPool's majority) and switiching is definitely not in their immediate best interest -- possibly not in their interest at all. Does Bitcoin's security model in this situation rely on nothing more than the altruistic feelings of hashers? Hoping that hashers will do "the right thing" even when it's contrary to their immediate best interest?
Nice write-up! I think hashers acting "in their immediate best interest" is maybe a fair but not entirely accurate assumption. A lot of hashers are very knowledgeable about Bitcoin and would not put immediate best-interest over the viablility of the project as a whole. Why risk killing the goose? Something like this happened when Gigahash.io got a bit over 50% years ago. The pool didn't even exist for very long after that. If hashers feel legitimately threatened they will act, imo.
reply
A lot of hashers are very knowledgeable about Bitcoin and would not put immediate best-interest over the viablility of the project as a whole
That's the big unknown. It's curious to me that Bitcoin security relies to some extent on people being knowledgeable and farsighted.
It's kinda like assuming that Bitcoin developers are more likely to report a bug than exploit it. While we may hope this happens, sure doesn't seem like a great way to operate.
Don't we have to assume Bitcoin exists in the most adversarial environment possible?
reply
This was a great read.
There's a repeated game element to add on to the end, I think. As censored transactions become more normal and therefor more profitable for potential miners, bitcoin mining itself will become more profitable in places that don't cooperate with the censors. Censorship, or even the realistic prospect of censorship, will induce geographic decentralization of mining.
For now, it sounds like, the pools are basically behaving themselves sufficiently well to not drive hashrate away.
I also thought your point about how "bad" the censorship would need to be was interesting. Depending on what the transactions are being censored for, I'm sure many people will approve of it. Some may even join pools specifically because of what they censor.
This is definitely a topic I need to think through a bit more.
reply
You're right: geography certainly is huge. I probably should have noted the geographic distribution of energy sources as the other major decentralizing pressure in mining. But it's also true that pooling can lessen the effects of geography.
One of the worst case scenarios would be a light, but mostly acted-upon agreement among the top four or five pools to exclude transactions from OFAC-sanctioned addresses coupled with a lackluster outrage from hashers where few of them actually switch pools.
reply
Thanks for the interesting analysis.
I agree with you that there's a counterbalancing force to censorship, that the economic value of sanctioned tx's go up, which eventually may incentivize someone to process those tx's.
Still, I would worry that it takes so long for that to happen, or the fees get so high, that Bitcoin becomes practically unusable for sanctioned addresses. Thus forcing sanctioned individuals to use another coin, or use fiat, to do conduct their business.
I think the solution to censoring is going to be some combination of legal/geographical decentralization, and privacy/anti-kyc tech.
reply
Still, I would worry that it takes so long for that to happen, or the fees get so high, that Bitcoin becomes practically unusable for sanctioned addresses. Thus forcing sanctioned individuals
Individuals, sanctioned or not, should not reuse addresses. One address per UTXO. And they can use payjoins to break the common input owner heuristic. If the censors like to mark coins as tainted, let's get them all marked tainted. The more addresses are tainted the more profits the OFAC-compliant pools lose.
reply
Very entertaining read. Not sure if it'll work out the way it is being theorized, but it's a neat example of game theory potentially leading to the best outcome for Bitcoin.
reply
Yeah, so much is just thinking about what people might do.
Maybe when the time comes all the hashers stick with the pool even though it censors because they offer bonus free Taylor Swift concert tickets.
reply
I wonder if there is any argument to be made for a future where solominers play a role again. I guess their aggregate hash power doesn't even show in the chart above?
reply
At the moment, solo mining pretty much means losing out on profits. Unless you are a really big solominer with a lot of hashpower, you probably aren't solving a block this decade.
On the other hand, maybe you are running a bitcoin mining water heater and you like to play the lottery.
I'm not sure how a widespread adoption of "byproduct hashpower" changes things. Interesting to consider.
But it seems likely that pure, for-profit mining will always be the dominant portion of hash power.
reply
Yeah, I was definitely not thinking about it being useful for the individual. But if 1000s of people consider this lottery mining as something they are willing to pay for (without likely profits), as an aggregate, you start forming the equivalent of a small pool of "idealistic" miners, who likely will have less pressure to censor.
On second reading, I guess that's what you referred to as "widespread adoption of "byproduct hashpower".
But it seems likely that pure, for-profit mining will always be the dominant portion of hash power.
I agree.
reply
116 sats \ 1 reply \ @nym 23 Jan
Almost like the Streisand Effect
reply
Excellent analogy!
reply
reply
Good article. Thanks for linking.
reply
I like this. Although Bitcoin thrives when attacked in any way; not only txn censorship. Censoring, rehypothecating, spreading mis-information, double-spending, mining empty blocks... it doesn't matter. Eventually Bitcoin gets stronger, wrecks you, and moves on.
reply
So many things in Bitcoin are like this. The difficulty adjustment is usually the first one that comes to mind, but the more you think about it, the self-balancing starts to show up all over the place.
reply
I understand the economic incentive not to censor transactions, but is that enough? Is bitcoin losing the battle of censorship resistance?
reply
I don't think so at all.
For me, the gravest concern re bitcoin censorship resistance is the prevalence of extensive kyc and the lack of privacy in transactions.
If the state can connect a physical address to a bitcoin address, they can put you in jail even if they can't stop your transaction.
reply
It’s not just miners either. It’s also nodes.
For instance, I think I purge any txs over 2GB in my MemPool.
reply
I'm not sure that I follow you.
Nodes choosing to relay or not relay transactions doesn't cause censorship in the way a mining pool can.
See footnote #3 in the OP. Tl;dr is that even if a large majority of nodes purge a transaction, a few nodes choosing to relay it makes it very likely the transaction will make it to miners.
Or am I misunderstanding your point?
reply
I’m not pushing back on anything you’re saying. I’m simply adding to it.
Miners are the only ones that can censor transactions the way that they do but I guess all I am saying is that individual actors choose to omit certain types of data that they don’t need/want/like.
Nostr paid relays work in a similar way. They are able to censor and not relay a specific message or block certain users.
reply
Great writeup.
reply
We need more decentralized mining. With more pools and only decentralized pools. Through Tor and VPN.
Classic mining is a crutch
reply
Amazing read. It will be interesting to see how it all plays out over time.
reply
🚩 This post might be more relevant and engaging in the ~bitcoin_Mining territory.