Pooled mining
Also covering Betterhash, Braidpool, Stratum, and Stratum v2
Pooled mining occurs when two or more independent miners collaborate on finding proof of work for new blocks, with them fairly dividing the rewards of any blocks they find. Betterhash, Braidpool, Stratum, and Stratum v2 are protocols for coordinating pooled mining.
Hashing a block header will produce a value that can be interpreted as a number. Hashing many unique block headers using double-SHA256 will produce a uniform distribution of numbers within the range 0 to 2256-1. For example, approximately 1% of the numbers will have values less than 1% of the range’s maximum value. For a block to contain enough proof of work to be valid, its header must hash to a value below a target value that is dynamically set by the protocol. For example, if the target value is 1% of the range maximum, each hash of a unique header has a 1% chance of being below the target.
A corollary of the above is that each hash that is below the target value will belong to a set of hashes that is below some higher target. For example, if the primary target value is 1%, we would expect every hash below that value to have resulted in finding an average of 9 other hashes that are all below a secondary target of 10%. A header hash below a secondary target is called a share in pooled mining. Only shares below the primary target can produce a valid block, but each share demonstrates an amount of proof of work in the same proportion as the primary target to the secondary target. For example, if the primary target is 1% and the secondary target is 10%, each share proves an amount of work equal to 10% of the average work needed to create a block.
The use of shares allows pools to efficiently and equitably track how much work is contributed by each member of a pool. In a simple payout scheme, such as pay per share (PPS), a pool may pay Alice 10% of a typical block reward for each 10% share she submits. This allows Alice to profit even if she doesn’t personally find a hash with the 10x higher amount of proof of work needed for a valid block. If Alice does find a proof of work demonstrating that required 10x higher value, a pure PPS scheme will still only pay her for one share (e.g. 10%). PPS schemes face various problems in practice, some of which we’ll describe later in this article, but PPS provides a simple framework for understanding how miners can equitably divide the rewards from producing blocks.
Shares are a type of weak block. They need to follow at least two rules:
-
A share must be either a valid block or what would have been a valid block if it had a header hash below the primary target.
-
The coinbase transaction must follow a template provided by the pool. For example, all pools we know of use the coinbase transaction to pay either the pool operator (who later distributes rewards to pool members) or to pay pool members directly.
Pools may impose additional requirements on their members, either explicitly or by using a pool protocol that does not give members the flexibility to make certain choices.
Pool protocols
The earliest pool protocol was built around transmitting block header
templates in the format used by the early Bitcoin Core RPC getwork
.
When the speed of mining equipment made that impractical, an early
attempt at creating a distributed mining protocol was specified in BIPs
22 and 23, with a partial implementation in Bitcoin
Core as the getblocktemplate
RPC. GetBlockTemplate never saw
widespread usage as a pool protocol itself, although many centralized
pool servers have used it for the past decade in the background to obtain
a good set of transactions to mine from their local Bitcoin Core node.
As the GetWork-based protocol became problematic, most mining pools switched to the Stratum protocol (v1). Stratum v1 allows pools to only send their members a template for a block header and a coinbase transaction, which can be less than 200 bytes. When a member finds a share, they can send back roughly the same information. This very compact information minimizes the overhead of the pool protocol. The downside of the way GetWork and Stratum v1 are typically used is that pool members have no insight or direct control over what they mine. They aren’t directly informed about which transactions are included in the template block (or excluded from it) and the pool may reject any attempt they make to change those transactions. They are (by necessity) informed of what their block claims is the previous block header, but few Stratum v1 users ensure that is what their own full nodes think should be the previous block header; this lack of independent validation has allowed pools in the past to steal from website operators and lose money accidentally violating consensus rules. Although BIPs 40 and 41 were reserved for Stratum v1, documentation for them has never been provided.
Betterhash was a proposed mining pool protocol that allowed pool members to select which transactions to include in the blocks they create. The protocol also made it easy for pool members who found a new block to submit it directly to the network through their Bitcoin full node, which could reduce propagation times and improve the chance of that block becoming a permanent part of the block chain. Additional improvements in Betterhash focused on security and efficiently distributing work across multiple mining hardware devices. Although the proposal has not been withdrawn, it does appear that development of it has been replaced by development on Stratum v2.
Stratum v2 is an entirely new protocol developed by several of the same people who contributed to Stratum v1. It provides several of the same advantages as Betterhash, although sometimes using different mechanisms. Like Betterhash, one of its key advantages is that it can allow individual pool members to choose which transactions to include in their blocks. Stratum v2 is used in production as of this writing, although some advanced features are not fully supported by any widely deployed mining software.
BraidPool is a proposed design for a fully decentralized mining pool. Unlike a typical centralized mining pool managed with Stratum v1 or v2, members of a BraidPool must all chose their own transactions and funds will be paid for any valid share, preventing the pool from interfering with each individual member’s choices about what transactions to mine. BraidPool is inspired by the former P2Pool decentralized mining pool but attempts to mitigate some of P2Pool’s problems, including its reduced ability to capture fee income due to its large typical coinbase transactions and the frequency of P2Pool shares becoming stale. BraidPool is under active development as of this writing.
Pool payout schemes
Previously in this article, we’ve describe a single idealized payout: a miner who creates a 1/100th share for a block template with a block reward of 12.3456789 BTC will receive a payout of 0.1234567890 BTC. In practice, no pool we’re aware of pays exactly that way, and they use slightly different jargon. The following describes general types of payouts, although each pool’s implementation of them may differ from our descriptions and from other pools.
At the time of writing, many miners seem to prefer FPPS pools, possibly due to it being easy to determine in advance how much they’ll be paid for contributing a particular amount of hashrate.
Primary code and documentation
Optech newsletter and website mentions
2024
- Stratum v2 benchmarking tool released
- Stratum.work website with real-time visualization of Stratum messages from several mining pools
- Bitcoin Core #30200 adds a new mining interface to better support Stratum v2 in the future
- How does the TIDES payout scheme work?
2023
2022
2021
2018
Previous Topic:
Peer storage
Next Topic:
Proof of payment