Basechain
  • About Basechain
  • Base BigBang Language
    • Introduction
    • 1. Getting started
      • 1.1 Installing BigBangNet
      • 1.2 BigBang basics
    • 2. Type
      • 2.1 Primitives
      • 2.2 Sequences
      • 2.3 Composites
    • 3. Keywords
    • 4. Storing data
      • 4.1 Constants
      • 4.2 Variables
      • 4.3 Maps
    • 5. Functions
      • 5.1 Public functions
      • 5.2 Private functions
      • 5.3 Read-only functions
  • 6. Control flow & error handling
    • 6.1 Asserts
    • 6.2 Try
    • 6.3 Unwrap flavours
    • 6.4 Response checking
  • 7. Using BigBangNet
    • 7.1 Creating a new project
    • 7.2 Writing your first contract
    • 7.3 Interacting with your contract
    • 7.4 Testing your contract
  • 8. Practice projects
    • 8.1 Time-locked wallet
    • 8.2 Smart claimant
    • 8.3 Multi-signature vault
  • 9. Traits
    • 9.1 Defining traits
    • 9.2 Implement traits
    • 9.3 Passing traits as arguments
  • 10. Building a marketplace
    • 10.1 Setup
    • 10.2 Listing & cancelling
    • 10.3 Fulfilling listings
    • 10.4 Uni tests
  • 11. Runtime cost analysis
  • Nodes & Miners
    • Run a Node with Docker
    • Run a Node with DigitalOcean
    • Run a Node with a Hosted Provider
    • Base Node Configuration
    • Mine testnet Base tokens
    • Verify Miner
    • Miner costs and fees
  • Website
  • X(Twitter)
  • Github
Powered by GitBook
On this page
  • Introduction
  • Running a Bitcoin Testnet Full Node​
  • Update the Bitcoin Configuration File​
  • Start Bitcoin​
  • Running a Base Blockchain miner​
  • Generate a keychain​
  • Update the Base Blockchain Configuration File​
  • Start the Base Blockchain​
  • Enable Debug Logging​
  • Optional: Running a Base Blockchain miner with Docker​
  • Generate a Keychain and Get Some Tokens​
  • Update Base Blockchain Docker Configuration File​
  • Start the Base Blockchain miner with Docker​
  • Optional: Running in Kubernetes with Helm​
  • Generate keychain and get some tokens​
  • Install the chart and run the miner​
  1. Nodes & Miners

Mine testnet Base tokens

PreviousBase Node ConfigurationNextVerify Miner

Last updated 1 year ago

Introduction

To learn more about mining's technical details, please refer to the mining guide.The following is a condensed version of the walkthrough for a Linux system. If you are using Windows or MacOS, some slight modifications may be necessary (PR's welcome!).

Running a Bitcoin Testnet Full Node

To participate as a miner on testnet, you must have access to a testnet bitcoin node with a wallet (and the wallet's private key). One way to accomplish this is to run bitcoin locally.

First, download a

TIP

It is recommened to use a persistent location for the chainstate, in the steps below we're using /bitcoin

Update the Bitcoin Configuration File

Next, update the bitcoin configuration:

  • optional but recommended: Use a persistent directory to store the Bitcoin chainstate, i.e. datadir=/bitcoin

  • optional but recommended: Update the rpcallowip value to only allow 127.0.0.1, or the base miner IPv4

  • Modify the rpcuser and rpcpassword values from the defaults below

  • Store the following configuration somewhere on your filesystem (ex: $HOME/bitcoin.conf)

server=1
testnet=1
disablewallet=0
datadir=/bitcoin
rpcuser=btcuser
rpcpassword=btcpass
rpcallowip=0.0.0.0/0
dbcache=512
banscore=1
rpcthreads=256
rpcworkqueue=256
rpctimeout=100
txindex=1

[test]
bind=0.0.0.0:18333
rpcbind=0.0.0.0:18332
rpcport=18332

Finally, start bitcoind as follows:

bitcoind -conf=$HOME/bitcoin.conf

NOTE

The node will need a few hours to synchronize with the Bitcoin testnet.

While it's syncing, you can track the progress with bitcoin-cli or the logfile (will be located where the chainstate is stored, i.e. /bitcoin/testnet3/debug.log):

$ bitcoin-cli \
 -rpcconnect=localhost \
 -rpcport=18332 \
 -rpcuser=btcuser \
 -rpcpassword=btcpass \
getblockchaininfo | jq .blocks
2417570

First, download a Base blockchain binary, or build from source

TIP

It is recommened to use a persistent location for the chainstate, in the steps below we're using /base-blockchain

First, a keychain needs to be generated. With this keychain, we'll get some testnet BTC from a faucet, and then use that BTC to start mining.

To create a keychain, the simplest way is to use the base-cli with the make_keychain command.

npx @base/cli make_keychain -t 2>/dev/null | jq -r

After this runs, you should see some JSON printed to the screen that looks like this:

{
  "mnemonic": "exhaust spin topic distance hole december impulse gate century absent breeze ostrich armed clerk oak peace want scrap auction sniff cradle siren blur blur",
  "keyInfo": {
    "privateKey": "2033269b55026ff2eddaf06d2e56938f7fd8e9d697af8fe0f857bb5962894d5801",
    "address": "STTX57EGWW058FZ6WG3WS2YRBQ8HDFGBKEFBNXTF",
    "btcAddress": "mkRYR7KkPB1wjxNjVz3HByqAvVz8c4B6ND",
    "index": 0
  }
}

DANGER

Do not lose this information - we'll need to use the privateKey and btcAddress fields in later steps.

The above btcAddress (mkRYR7KkPB1wjxNjVz3HByqAvVz8c4B6ND) will then need to be imported into the bitcoin testnet network.

NOTE

Be sure to replace <btcAddress from JSON above> with the bitcoin address in the "Generate a keychain" step

bitcoin-cli \
  -rpcport=18332 \
  -rpcuser=btcuser \
  -rpcpassword=btcpassword \
importaddress <btcAddress from JSON above>

Now, we need to configure our node to use this Bitcoin keychain.

Now, grab your privateKey from earlier when you ran the make_keychain command. Replace the seed and local_peer_seed field with your private key. Save and close this configuration file.

Next, update the bitcoin configuration:

  • optional but recommended: Use a persistent directory to store the Base chainstate, i.e. working_dir = "/base-blockchain"

  • From the make_keychain step, modify the seed and local_peer_seed values with privatekey

  • Store the following configuration somewhere on your filesystem (ex: $HOME/testnet-miner-conf.toml)

[node]
working_dir = "/base-blockchain"
rpc_bind = "0.0.0.0:20443"
p2p_bind = "0.0.0.0:20444"
seed = "<keychain privateKey>"
local_peer_seed = "<keychain privateKey>"
miner = true
bootstrap_node = "047435c194e9b01b3d7f7a2802d6684a3af68d05bbf4ec8f17021980d777691f1d51651f7f1d566532c804da506c117bbf79ad62eea81213ba58f8808b4d9504ad@testnet.base.tech:20444"
wait_time_for_microblocks = 10000

[burnchain]
chain = "bitcoin"
mode = "xenon"
peer_host = "127.0.0.1"
username = "<bitcoin config rpcuser>"
password = "<bitcoin config rpcpassword>"
rpc_port = 18332
peer_port = 18333

[[ustx_balance]]
address = "ST2QKZ4FKHAH1NQKYKYAYZPY440FEPK7GZ1R5HBP2"
amount = 10000000000000000

[[ustx_balance]]
address = "ST319CF5WV77KYR1H3GT0GZ7B8Q4AQPY42ETP1VPF"
amount = 10000000000000000

[[ustx_balance]]
address = "ST221Z6TDTC5E0BYR2V624Q2ST6R0Q71T78WTAX6H"
amount = 10000000000000000

[[ustx_balance]]
address = "ST2TFVBMRPS5SSNP98DQKQ5JNB2B6NZM91C4K3P7B"
amount = 10000000000000000

To run your miner, run this in the command line:

base-node start --config=$HOME/testnet-miner-conf.toml

Your node should start. It will take some time to sync, and then your miner will be running.

In case you are running into issues or would like to see verbose logging, you can run your node with debug logging enabled. In the command line, run:

BASE_LOG_DEBUG=1 base node start --config=$HOME/testnet-miner-conf.toml

Alternatively, you can run a Base testnet miner with Docker.

CAUTION

Generate a keychain:

docker run -i node:14-alpine npx @base/cli make_keychain 2>/dev/null | jq -r

Now, we need to get some tBTC. Grab the btcAddress field, and paste it into this Bitcoin testnet faucet. You'll be sent 0.01 tBTC to that address.

INFO

The ENV VARS RUST_BACKTRACE and BASE_LOG_DEBUG are optional. If removed, debug logs will be disabled

docker run -d \
  --name base_miner \
  --rm \
  --network host \
  -e RUST_BACKTRACE="full" \
  -e BASE_LOG_DEBUG="1" \
  -v "$HOME/testnet-miner-conf.toml:/src/base-node/testnet-miner-conf.toml" \
  -v "/base-blockchain:/base-blockchain" \
  -p 20443:20443 \
  -p 20444:20444 \
  blockstack/base-blockchain:latest \
/bin/base-node start --config /src/base-node/testnet-miner-conf.toml

You can review the node logs with this command:

docker logs -f base_miner

In addition, you're also able to run a Base miner in a Kubernetes cluster.

Ensure you have the following prerequisites installed:

To install the chart with the release name my-release and run the node as a miner:

minikube start # Only run this if standing up a local Kubernetes cluster
helm repo add blockstack https://charts.blockstack.xyz
helm install my-release blockstack/base-blockchain \
  --set config.node.miner=true \
  --set config.node.seed="replace-with-your-privateKey-from-generate-keychain-step" \

You can review the node logs with this command:

kubectl logs -l app.kubernetes.io/name=base-blockchain

Start Bitcoin

Running a Base Blockchain miner

Generate a keychain

Once imported, we need to get some testnet BTC to that address. Grab the btcAddress field, and paste it into . You'll be sent 0.01 testnet BTC to that address.

Update the Base Blockchain Configuration File

Start the Base Blockchain

Enable Debug Logging

Optional: Running a Base Blockchain miner with Docker

Ensure you have installed

Generate a Keychain and Get Some Tokens

Update Base Blockchain Docker Configuration File

Use the steps oulined above to create the

Start the Base Blockchain miner with Docker

Optional: Running in Kubernetes with Helm

(Only needed if standing up a local Kubernetes cluster)

Generate keychain and get some tokens

Use the steps

Install the chart and run the miner

​
Ensure your computer meets the minimum hardware requirements before continuing.
bitcoin binary
​
​
​
​
this Bitcoin testnet faucet
​
​
​
​
Docker
​
​
configuration file
​
​
Docker
minikube
kubectl
helm
​
outlined above
​