This repository contains materials for a StratumV2 Reference Implementation workshop.
- For useful materials see the materials/ directory.
These instructions cover the setup required for the instructor running the Stratum V2 workshop.
- Configuring and hosting the slides to be accessible by the participants.
- Configuring a publicly accessible Genesis node for participants to sync their nodes.
- Configuring the block explorer to display participants' mined blocks.
- Setting up a reproducible build for participants using Docker.
Files under html
directory are built with marp
, based on the files under md
.
marp md/sv2-workshop.md -o html/sv2-workshop.html --theme-set css/sv2-theme.css
marp md/sv2-intro.md -o html/sv2-intro.html --theme-set css/sv2-theme.css
Or, if using nix
, run (assuming nix flakes are available):
nix run github:tweag/nix-marp -- md/sv2-workshop.md -o html/sv2-workshop.html --theme-set css/sv2-theme.css
nix run github:tweag/nix-marp -- md/sv2-intro.md -o html/sv2-intro.html --theme-set css/sv2-theme.css
Serve the slides:
python3 -m http.server 8080
To make the slides accessible on the SRI VPS for participants to view on their machines:
- Remote into the SRI VPS.
- Create a new
tmux
session. cd ~/sv2-workshop
.- Make sure the correct
workshop
branch (or branch of your choosing) is checked out. - Run the HTTP server.
Note: This can be done on any machine, however the slides specifically point the user to the SRI VPS URL. If you choose to host the slides on another machine, remember to update the slides with the update endpoint.
This workshop uses a custom signet
for the following reasons:
- We want a confined hashrate environment, so
mainnet
,testnet3
,testnet4
and the publicsignet
are ill suited. regtest
is too isolated and requires manual block generation, which is not practical for a collaborative workshop setting.- We will mine on a custom
signet
that does not require coinbase signatures. - This way, we can deploy pools + hashers and emulate a confined hashrate environment.
Participants will connect to this Genesis node to sync their blocks.
The instructor can use the existing Genesis node hosted on the SRI VPS, or spin up their own. The Genesis node should be configured via the materials/signet-genesis-node.sh script which:
- Deploys a local signet.
- Mines 16 blocks as bootstrapping for the SRI pool.
Before executing the script, ensure the following environment variables are defined on materials/env.sh
:
$BITCOIND
: path tobitcoind
$BITCOIN_CLI
: path tobitcoin-cli
$BITCOIN_UTIL
: path tobitcoin-util
$MINER
: path tominer
, usuallybitcoin/contrib/signet/miner
$BITCOIN_DATA_DIR
: path to bitcoin data dir
A Genesis node that is publicly accessible is needed for participants to sync their Bitcoin nodes. This can be set up by the instructor or use the existing SRI VPS node.
If using the SRI hosted Genesis node, verify it is running by remoting into the SRI VPS and finding its process:
ps -ef | grep -i bitcoind
> sri 3935787 1 0 Jun29 ? 01:19:13 /home/sri/btc_prague_workshop/bitcoin/src/bitcoind -signet -datadir=/home/sri/btc_prague_workshop/bitcoin_data_dir/ -fallbackfee=0.01 -daemon -sv2 -sv2port=38442
If spinning up a new node, see the instructions to install bitcoin-core
in the Block Explorer
section below.
A block explorer is needed to display participants' mined blocks on the custom signet
. A custom
signet
Bitcoin node, electrs
, and
mempool.space
is used for this purpose.
Note: The steps for deploying a local
mempool.space
have not yet been automated and will need to be performed manually.
Note: The Genesis node can also be used for this purpose. A second Bitcoin node for the block explorer only is needed if the instructor is running the block explorer on another machine (like their local machine).
Note: The steps documented here have only been tested on an Ubuntu environment. It will likely not work properly on different environments (e.g.: MacOS).
Install the required bitcoin-core
fork by building from
Sjors's sv2-tp-0.1.9
tag:
git clone https://github.com/Sjors/bitcoin.git
cd bitcoin
git fetch --all
git checkout sv2-tp-0.1.9
cmake -B build
cmake --build build # use "-j N" for N parallel jobs
Ensure the bitcoin.conf
in the datadir
contains:
[signet]
signetchallenge=51 # OP_TRUE
prune=0
txindex=1
server=1
connect=75.119.150.111 # Genesis Node
rpcallowip=0.0.0.0/0
rpcbind=0.0.0.0
rpcuser=mempool
rpcpassword=mempool
Add the Bitcoin binaries to $PATH
:
echo 'export PATH="$HOME/bitcoin/src:$PATH"' >> ~/.bashrc && export PATH="$HOME/bitcoin/src:$PATH"
Start the Bitcoin node:
bitcoind -datadir=$HOME/.bitcoin-sv2-workshop -signet -sv2
Clone, checkout the v0.10.5
branch, and configure:
git clone https://github.com/romanz/electrs
cd electrs
git checkout v0.10.5
cat << EOF > electrs.toml
network="signet"
auth="mempool:mempool"
EOF
Run the server:
cargo run -- --signet-magic=54d26fbd
Clone and checkout the v2.5.0
branch:
git clone https://github.com/mempool/mempool
cd mempool
git checkout v2.5.0
The Docker deployment requires some adjustments to the docker/docker-compose.yml
.
You can automate these adjustments by:
- creating a
sv2-workshop.patch
file with the content below - running
git apply sv2-workshop.patch
inside themempool
repo directory.
diff --git a/docker/docker-compose.yml b/docker/docker-compose.yml
index 68e73a1c8..5d50229ba 100644
--- a/docker/docker-compose.yml
+++ b/docker/docker-compose.yml
@@ -2,25 +2,30 @@ version: "3.7"
services:
web:
+ network_mode: "host"
environment:
- FRONTEND_HTTP_PORT: "8080"
- BACKEND_MAINNET_HTTP_HOST: "api"
+ FRONTEND_HTTP_PORT: "1337"
+ BACKEND_MAINNET_HTTP_HOST: "127.0.0.1"
image: mempool/frontend:latest
user: "1000:1000"
restart: on-failure
stop_grace_period: 1m
- command: "./wait-for db:3306 --timeout=720 -- nginx -g 'daemon off;'"
+ command: "./wait-for 127.0.0.1:3306 --timeout=720 -- nginx -g 'daemon off;'"
ports:
- - 80:8080
+ - 80:1337
api:
+ network_mode: "host"
environment:
- MEMPOOL_BACKEND: "none"
- CORE_RPC_HOST: "172.27.0.1"
- CORE_RPC_PORT: "8332"
+ MEMPOOL_BACKEND: "electrum"
+ ELECTRUM_HOST: "127.0.0.1"
+ ELECTRUM_PORT: "60601"
+ ELECTRUM_TLS_ENABLED: "false"
+ CORE_RPC_HOST: "127.0.0.1"
+ CORE_RPC_PORT: "38332"
CORE_RPC_USERNAME: "mempool"
CORE_RPC_PASSWORD: "mempool"
DATABASE_ENABLED: "true"
- DATABASE_HOST: "db"
+ DATABASE_HOST: "127.0.0.1"
DATABASE_DATABASE: "mempool"
DATABASE_USERNAME: "mempool"
DATABASE_PASSWORD: "mempool"
@@ -29,10 +34,11 @@ services:
user: "1000:1000"
restart: on-failure
stop_grace_period: 1m
- command: "./wait-for-it.sh db:3306 --timeout=720 --strict -- ./start.sh"
+ command: "./wait-for-it.sh 127.0.0.1:3306 --timeout=720 --strict -- ./start.sh"
volumes:
- ./data:/backend/cache
db:
+ network_mode: "host"
environment:
MYSQL_DATABASE: "mempool"
MYSQL_USER: "mempool"
Start the Docker container:
cd docker
sudo docker compose up
Navigate to the machine's URL at port 8080.
The materials/Dockerfile
contain the Docker image with the following installed, configured, and built:
- Sjors's
sv2-tp-0.1.9
: Used for the Pool and Miner Roles. cpuminer
v2.5.1
: Used as hasher for the Miner Role.stratum
-workshop
branch: Theroles/
crates are used to run the Pool and Miner Roles.
To support participants opening multiple terminal sessions, tmux
is used. A tmux.conf
is
instantiated by the Docker image with the materials/setup-tmux.sh
.
This tmux.conf
will allow users to navigate between tmux
panes with a mouse click and also
includes a few more customizations for ease of use.
Note: This is connected to the
rrybarczyk
Docker Hub account and should eventually be transferred to a SRI Docker Hub account.
Build the image for both AMD64 and ARM architectures then run the image locally:
cp materials/setup-tmux.sh /usr/local/bin/setup-tmux.sh
docker buildx build --platform linux/amd64,linux/arm64 -t sv2-workshop:latest .
docker run -it --rm sv2-workshop:latest
For a faster local build time, use:
docker build -t sv2-workshop:latest .
Initial setup request login and establishing the tag (after locally building):
docker login
docker tag sv2-workshop:latest rrybarczyk/sv2-workshop:latest
Push to Docker Hub:
docker push rrybarczyk/sv2-workshop:latest
A single command to build and push to Docker Hub:
docker buildx build --platform linux/amd64,linux/arm64 -t rrybarczyk/sv2-workshop:latest --push .