Bitcoin Regtest Environment
Video of presentation can be found here.
Transcript of presentation can be found here.
Note: instead of 'generate', use 'generatetoaddress'
For more discussion of regtest and how it compares to the proposed signet see here and here.
Introduction
The goal of this presentation is to set up a development environment, where you can run multiple nodes in a simulated environment without having to sync to testnet. We will set up 3 nodes and experiment with the cli/rpc commands to send transactions between nodes and analyze the makeup of a transaction.
Install Bitcoin Core
If you don't have the Bitcoin Core software installed on your computer, you can install it here.
Remember to add bitcoind and bitcoin-cli to your path. If you don't know how, raise your hand.
Run 3 Regtest Nodes
This script runs 3 regtest nodes
bash run.sh
Command Sequence
Balances
(as regtest, preceed following commands with bitcoin-cli -regtest
)
Just the three of us?
getpeerinfo
How much money do we have?
getbalance
Looks like we're broke. Anyone know why?
Have there been any blocks mined? Without blocks we're all broke!
getblockchaininfo
First, we need to grab an address from someone to mine to:
getnewaddress
Notice that the height is 0. This means we need to mine some blocks. In regtest we can mine without POW:
generatetoaddress 1 <address generated above>
Now we're rich -- 50 bitcoins!
getbalance
Still 0. What happened? In bitcoin we have a 100 block maturity time for newly mined coinbase transactions (explanation
Let's mine 100 more (to any address in our network) -- giving us 1 mature transaction
generatetoaddress 100 <address>
Are we rich yet?
getbalance
Yes, we are rich!
Transactions
We ran 3 nodes. The default regtest node now has 50 bitcoins, but Alice and Bob are still broke. In fact, they don't even have bitcoin addresses yet.
To run bitcoin-cli commands as alice, you can source aliases.sh
, which will create alice-cli
and bob-cli
terminal aliases that run bitcoin-cli
commands with the correct parameters for Bob and Alice.
alice-cli getbalance
Alice is broke as expected
alice-cli getnewaddress
Let's send Alice some coin
bitcoin-cli -regtest sendtoaddress <alice's address from above> 1
alice-cli getbalance
Alice is still broke
alice-cli listunspent 0
The 0 is for minimum confirmations, now we see Alice's transaction as unconfirmed, it will show in her balance once a block is mined.
Exercise: send a transaction from Alice to Bob and verify that Bob has received
Additional Topics
makeup of a transaction
run simulate.js
and show how it is useful
create, sign and send raw transactions
create, sign and send multisig transaction
Install nodes-debug(optional)
This project is a little easier to use than bitcoin-cli
. If you'd like, install it:
git clone https://github.com/rsbondi/nodes-debug.git
Run the app
cd nodes-debug
npm run dev
or follow the readme to build and run the binary
Optionally using bitcoin-qt
Assuming bitcoin-qt is in your path and you are in the project directory with no instances running
./qt.sh
Optionally simulate
node simulate.js
will randomly create transaction and mine on default regtest node. This will give more of a real world feel with mempool transactions and blocks getting automatically mined. Be sure that before running you mine enough on the default node with the generate
command so it will have money to spend
Additional resources
Learning-Bitcoin-from-the-Command-Line This is a good hardcore deep dive into the CLI
A Map of the Bitcoin Core RPC API across Versions A nice tabular view of all the RPC commands and the history of changes, showing deprecation, removal and addition of commands per version.