The message delimiter on the bitcoin network.
Magic bytes are used as a way to identify the separate messages sent between nodes on the bitcoin network.
For example, if you are trying to connect to a node with your own code, every message you send to that node should begin with
f9beb4d9, and every message you receive from that node will start with the same magic bytes too.
The magic bytes.
Magic bytes are 4 bytes in length, and will be different depending on which network you’re on:
version message I received from a node on the Testnet3 network:
And here’s a
Magic bytes are also used to separate block data in the blk*.dat files.
Why use Magic Bytes?
If you connect to a bitcoin node, think of the messages you get from it as a continual stream of data.
If you are trying to read this data, it’s good to have a reliable way of knowing when a new message starts (and ends). This is why a specific set of “magic bytes” are used as a “marker” so that you can always identify the start of a new message.
So there’s nothing actually magical about magic bytes – it’s just a way of segmenting data.
Why these bytes in particular?
These bytes have no specific meaning, except for:
The message start string is designed to be unlikely to occur in normal data. The characters are rarely used upper ASCII, not valid as UTF-8, and produce a large 32-bit integer with any alignment. – chainparams.cpp
So they could be different, but these are just 4 bytes that have the properties that make for good magic bytes on the bitcoin network.