Loading Tool

Blockchain

A big file of bitcoin transactions

Diagram showing the blockchain as a file stored by nodes on the bitcoin network.
Current Blockchain Size:
851.36 GB
953,453 blocks
Note: This is the size of the blockchain for my local node.
The size of your blockchain will differ depending on how many chain reorganizations your node has experienced and how many stale blocks you have stored on disk.

The blockchain is a file of transactions. It's the most important file that a bitcoin node maintains.

It is called the "blockchain" because new transactions are added to the file in blocks, and these blocks are built on top of one another to create a chain of blocks. Hence, blockchain.

But ultimately, the blockchain is permanent storage for bitcoin transactions.

Live Bitcoin Blockchain:

Tip: 953,453 (0 blocks away) ⇈
Next 0 blocks ↑
Height Block Hash Txs Size Avg Feerate AFR Time (UTC)
953,453 953,453 00000000000000000001f062c4213f165921217e14ee6e7709b8bcf730106fb6 5,015 1.00/1.00 vMB 1 ago
953,452 953,452 000000000000000000012572b661eb15fb499cc5010405ecd57d48ea50f94b41 4,652 1.00/1.00 vMB 1 ago
953,451 953,451 00000000000000000001d09d6f212297e96401f7544ce15e79c23b438d84112d 4,621 1.00/1.00 vMB 2 ago
953,450 953,450 000000000000000000015392872ff9e99800a731d0429c81f340e8a2cfb4ae27 6,369 1.00/1.00 vMB 0 ago
953,449 953,449 000000000000000000018bbeb827d41dc514f66f62b77b9f25d3ab2c509eae7a 6,337 1.00/1.00 vMB 1 ago
953,448 953,448 0000000000000000000163167bf7d65eb628f879805d110290f0d172297a8805 5,712 1.00/1.00 vMB 1
953,447 953,447 00000000000000000001dec02b8d8295e26b136ca05eec34537de9571edb94ad 4,834 1.00/1.00 vMB 1
953,446 953,446 00000000000000000000ff507859e30933f28557ea3a37701fbf67ef14d37a7e 4,495 1.00/1.00 vMB 2
953,445 953,445 000000000000000000007061d28a46903b9fc2aae7bd6594458565f956ed655b 6,193 1.00/1.00 vMB 1
953,444 953,444 00000000000000000000d2ab1ed8e35aada93d76a82c2be55e84db410aac903b 4,960 1.00/1.00 vMB 2
953,443 953,443 0000000000000000000031409384660c0ac778c8126dcbcc2ec495a18eb38574 6,354 1.00/1.00 vMB 0
953,442 953,442 00000000000000000001a7394541cac45f3084f45ab7b767b75d96f218cf428c 3,964 1.00/1.00 vMB 2
953,441 953,441 00000000000000000001d8fd0ebc7ec6622aa2e877b445d46460a54fb164235d 6,619 1.00/1.00 vMB 0
953,440 953,440 00000000000000000000a5f0d88e5418c9bdfe4f3cd9c480aae394257ceb46a8 6,447 1.00/1.00 vMB 0
953,439 953,439 00000000000000000000f5816d601a98b343fe7541638e8a2f6caeb75767def9 4,158 1.00/1.00 vMB 2
953,438 953,438 000000000000000000015149db43fabac446cff73e088105b58aafb447f0eda1 6,263 1.00/1.00 vMB 1
953,437 953,437 000000000000000000009b8dbab93bb510f31f78b4807d500ad64b603159d8b2 5,308 1.00/1.00 vMB 2
953,436 953,436 00000000000000000000d8e23a6b3cd6100258ea98042f4c31d242d553314b50 6,213 1.00/1.00 vMB 0
953,435 953,435 00000000000000000000f08942e2ef9a9a79a3cf9b3e8d0a70bcf9771b2a03b1 5,715 1.00/1.00 vMB 1
953,434 953,434 00000000000000000001dd0c30544d7ee43da3f48abda13141925db3c1ed6b81 4,107 1.00/1.00 vMB 1
953,433 953,433 000000000000000000011c268526c9134c0696b644d27094700d47fac0ff51c8 4,191 1.00/1.00 vMB 2
Previous 10 blocks ↓
Total Size: 851.36 GB

Download

How do you get a copy of the blockchain?

Diagram showing the blockchain being downloaded from other nodes on the network.

The easiest way to get a copy of the blockchain is to run a Bitcoin node.

When you run the Bitcoin program (e.g. Bitcoin Core) your node will automatically download blocks from other nodes on the network until you have an up-to-date copy of the blockchain on your computer.

When nodes connect to each other, they tell each other the height of their chain (how many blocks they have) during the initial handshake. If another node has more blocks than you, your node will request these blocks from the other nodes until you have a full copy of the blockchain.

As a result, nodes are constantly communicating with each other to replicate the blockchain across every computer on the network.

There is no single or definitive version of "the blockchain". Every node keeps their own local copy of the blockchain, and it can vary from computer to computer at any given time.

It can take a while to download the full blockchain when you run Bitcoin for the first time. This is referred to as the Initial Block Download (IBD).

Mining

How are new blocks added to the blockchain?

Diagram showing the a block being mined on to the blockchain by a node on the network.

New blocks of transactions must be mined on to the blockchain.

In short, the process of mining involves collecting transactions from the memory pool into a candidate block, and then using processing power to produce a block hash that is below a specific target value. This means that any node on the network can mine a new block, but you need to use energy to be able to do so.

tool-6a2cb87a5df9f
Tool Icon

Block Hash

Create a block hash from a block header.

0 bytes

Used internally inside raw block headers

0 bytes

Used externally when searching for blocks on block explorers

0 bytes
0 secs
tool-6a2cb87a5e099
Tool Icon

Target Adjustment

Calculate the next target value based on the current target and the time between blocks.

0x
0 bytes
Time (seconds)
0d
0d

The target adjustment period is 2016 blocks. A block is mined on average every 600 seconds (10 minutes), so the expected time is 2016 * 600 = 1209600 seconds.

Ratio

The actual time divided by the expected time. We multiply the current target by this ratio to get the new target.

0x
0x
0 bytes

Note: This target value has been truncated slightly for storage in the bits field of the block header, and that's the target value that's actually used when mining.

0 secs

When a node (or "miner") successfully mines a new block, they will share it with the other nodes on the network. When other nodes receive this new block, they will add it to their blockchain, and miners will start trying to mine a new block on top of it.

Diagram showing a newly-mined block being propagated to other on the network.

As a result, miners are constantly working to extend the blockchain with new blocks of transactions.

  • Due to the processing power required to mine a block and the regularly adjusting target, new blocks are added to the blockchain once every 10 minutes (on average).
  • A node doesn't have to try and mine new blocks. Instead, it can just keep a copy of the blockchain and relay new blocks to other nodes when it receives them.

Here's a video on how mining works in Bitcoin.

Chain Reorganizations

Can two blocks be mined at the same time?

As the blockchain is being built, it's perfectly normal for two blocks to be mined at the same time.

Diagram showing a temporary fork in the blockchain due to two blocks being mined at the same time.
If two blocks are mined at the same time it will cause a temporary "fork" in the chain.

In this situation, nodes will consider the first block they receive as part of their blockchain, but also keep the second block they receive just in case. However, the second block to arrive (and the transactions inside it) will not be considered as part of their active blockchain.

Consequently, nodes on the network will be in temporary disagreement about which of these two blocks belongs at the top of the chain.

This disagreement is resolved when the next block is mined. The next block will be built on top of one of these blocks, creating a new longest chain of blocks, and as a rule nodes will always adopt the longest known chain of blocks as their active blockchain.

As a result, nodes with the shorter chain will perform a chain reorganization to move out blocks from their old active chain in favor of blocks that make up a new longer chain.

Diagram showing a temporary fork in the blockchain being resolved via a chain reorganization.
A fork is resolved when a new block is mined, as this will create a new longest chain.

So although there may be disagreements across the network about which block(s) belong at the top of the blockchain at any given time, the mining of new blocks and the adoption of the longest chain means that nodes will always eventually be in sync.

A temporary fork like this is rare. This happens about once a month (roughly), and usually only affects the top block on the blockchain.

Longest Chain

Can blocks in the blockchain be replaced?

Due to the way the blockchain is built, it's possible for blocks at the top of the chain to be replaced.

Nodes always adopt the longest chain as the "true" version of the blockchain. Therefore, you could always try and build a new longer chain of blocks to replace an existing one, and every node on the network will adopt it.

As a result, this allows you to "undo" or reverse a bitcoin transaction from the blockchain.

Diagram showing nodes on the network adopting the longest chain of blocks as their blockchain.
If you build a new longest chain of blocks, other nodes will adopt it as their blockchain.

However, the problem is that all miners are incentivized to always be building on top of the longest known chain. This means that the combined processing power of miners on the network will be focused on building one single chain, which will be built faster than any chain you could build on your own.

Diagram showing nodes on the network adopting the longest chain of blocks as their blockchain.
Miners naturally work to extend the current longest chain.

In other words, the combined processing power of the network working to build the blockchain helps to protect blocks (and transactions) that have already been mined on to the blockchain.

So the only way you could perform an intentional chain reorganization (to "undo" a transaction in an existing block) would be to have more processing power than every other miner combined so that you could out-mine the network and build a longer chain for everyone to adopt. This is referred to as a "51% Attack".

Nobody has performed a successful 51% attack on the Bitcoin blockchain.

Location

Where is the blockchain stored?

If you're running a Bitcoin Core node, the blockchain files can be found in the following location on your computer:

The blockchain is split into multiple files named blk00000.dat, blk00001.dat, blk00002.dat, and so on. This is because it's easier to work with multiple small files than it is to work with one giant file. See blk.dat for details.

Summary

Diagram showing a blockchain being built by nodes across a network of computers.
Click on the image to see a nice and slow visualization of a blockchain being built over time, including a chain reorganization.

The blockchain is permanent storage for bitcoin transactions. New transactions are added to the file in blocks, and these blocks are built on top of each other to create a chain.

New blocks are added to the blockchain through mining, which involves the use of computer processing power. This means it takes energy to mine a block, but any node can work to try and add the next block on to the chain.

When a new block is mined, it will be relayed across the network, which nodes will verify and add on to their chain. This makes the blockchain a constantly growing ledger of transactions, distributed across multiple computers on a network.

Nodes always adopt the longest chain of blocks as the active version of the blockchain, which resolves disagreements about which blocks belong at the top of the chain. This also protects blocks that are already in the blockchain, as it would require large amounts of energy to build a chain that replaces blocks lower down in the chain.

The mechanism of mining and adopting the longest chain allows multiple computers over a network to agree on the same set of blocks and transactions, whilst also making it difficult for anyone to make historic changes to the blocks (and therefore transactions) in the blockchain.

As a result the blockchain is a secure, distributed, and regularly updated file of transactions.

Resources