If you are not familiar with the concept of signing and stacking, and how they work together, be sure to check out the Stackers and Signing concept guide.
This guide is a step-by-step walkthrough for actually setting up and running a signer. If you need to troubleshoot your signer setup, you can check out the Signer Troubleshooting section.
If you need to Stack your STX, or have questions about how that process works, check out the Stack STX guide.
In order to run a signer, you'll need to run a signer and a Stacks node side-by-side. Specifically, you'll want to run a testnet follower node. Instructions for doing this are listed below in the "Running Your Stacks Node" section. The signer will monitor for events coming from the stacks node and is in charge of using the generated account (next section) to sign incoming Stacks blocks sent from the Stacks node.
This doc will provide instructions on how to set up both using either Docker or building from source. Binaries will not be available in the initial release but will be released at a later date.
It will also walk through how to set up the config files to get the signer and Stacks node communicating correctly.
- Docker and basic knowledge of pulling and running images
- Basic knowledge of Stacks accounts
- Basic knowledge of stacking and the Stacking flow
Signer Checklist
Detailed steps for each of these are laid out below, but this checklist is being included as a way to quickly reference if you have taken all the appropriate actions to run a signer.
Pre-Launch Setup
- Ensure your system meets the minimum system requirements.
- Acquire Docker and basic knowledge of Stacks accounts, stacking, and the Nakamoto stacking flow (links provided below).
Preflight Setup
- Generate a new private key on testnet using stacks-cli.
- Save the generated account information securely.
Configuration Setup
- Create a
signer-config.toml
file with necessary configurations:- node_host
- endpoint
- network
- db_path
- auth_password
- stacks_private_key
- Store
signer-config.toml
securely and note down the values used.
Running the Signer
- Decide whether to run the signer using Docker (recommended) or as a binary.
- If using Docker:
- Set up the necessary ports and volumes.
- Run the Docker container with the appropriate settings.
- If running as a binary:
- Build
stacks-core
from source or download the pre-built binary. - Run the signer using the command:
stacks-signer run --config <path_to_config>
.
- Build
Verify Signer Operation
- Check that the signer is listening on its configured endpoint.
- Confirm that there are no errors and the system is ready for connections.
Setting Up the Stacks Node
- Create a
node-config.toml
with the necessary settings:- auth_token
- events_observer.endpoint (matching the signer configuration)
- Decide whether to run the Stacks node using Docker or as a binary.
- If using Docker:
- Set up the Docker container with the correct ports and volumes.
- Run the Stacks node Docker container.
- If running as a binary:
- Download the appropriate binary.
- Run it with the command:
./stacks-node start --config <path_to_config>
.
Verify Stacks Node Operation
- Check the Stacks node logs for successful connection to the signer.
- Confirm that the node is syncing Bitcoin headers properly.
Setup Stacks Accounts
- Set up a “pool operator” wallet in a Stacks wallet (e.g., Leather or Xverse).
- Fund the pool operator wallet with STX (testnet) sufficient for transaction fees.
- Share the pool operator wallet’s STX address with delegating parties.
- Fund your signer's STX wallet with enough STX to cover transaction fees (recommend at least 100-200 STX).
These are the minimum required specs to be able to run a node and signer, but it is recommended to have more than the minimum for optimal performance.
- 4 vcpu
- 4GB memory if running only a Stacks node and signer
- 10GB memory if running Stacks + Bitcoin node + signer
- 1.5+ TB storage (1TB for Bitcoin node, 350GB for Stacks node, and 50 GB for signer)
- 1 cpu
- 256MB memory
- 50GB storage
Before you get your signer set up, you'll need to generate a new private key on testnet. The stacks-cli
provides a mechanism for quickly generating a new account keychain via a simple CLI interface. The linked guide will show you how to create one of those accounts on testnet.
Once you follow the instructions linked above, be sure to save the information in a secure location, you'll need it in a future step.
{% hint style="info" %} What should the networking setup look like?
Signers are intended to work with a local node. The node<->signer connection is not run over SSL, which means you can be exposed to a man-in-the-middle attack if your signer and node are hosted on separate machines. Be sure you are aware of your networking setup, especially making sure your signer isn't allowing requests from the public internet. We recommend setting up your infrastructure to either have the signer and node running locally on the same machine or use only internal networking between them. {% endhint %}
Create a new file called signer-config.toml
. In that file, put the contents from the example signer config file from the Sample Configuration Files page. Each field is described on that page.
There are two options for running the signer: Docker and building from source. The recommended option is to use Docker. If you want to run as a binary, you will need to build stacks-core
from source. Instructions for how to do this are contained below in the relevant section.
{% hint style="warning" %} Note that at the moment the signer should only be run on testnet using these instructions. The mainnet release is still under development. {% endhint %}
You can run the signer as a Docker container using the blockstack/stacks-signer:3.1.0.0.3.0
image.
When running the Docker container, you’ll need to ensure a few things:
- The port configured as the
endpoint
(in the above linked example, “30000”) must be exposed to your Stacks node. Note that this endpoint should not be public, but must be exposed to your Stacks node - You’ll need a volume with at least a few GB of available storage that contains the folder your
db_path
is in. In the above example, that would be /var - You’ll need to include your
signer-config.toml
file as noted below with the first-v
flag
An example command for running the Docker image with ”docker run
” is shown below.
Be sure to replace the STX_SIGNER_PATH
with the correct path to your config file and where you want to install and run the signer. In this example it will be doing so in the current directory.
IMG="blockstack/stacks-signer"
VER="3.1.0.0.3.0"
STX_SIGNER_PATH="./"
STX_SIGNER_DATA="$STX_SIGNER_PATH/data"
STX_SIGNER_CONFIG="$STX_SIGNER_PATH/signer-config.toml"
docker run -d \
-v $STX_SIGNER_CONFIG:/config.toml \
-v $STX_SIGNER_DATA:/var/stacks \
-p 30000:30000 \
-e RUST_BACKTRACE=full \
-e BLOCKSTACK_DEBUG=0 \
--name stacks-signer \
$IMG:$VER \
stacks-signer run \
--config /config.toml
{% hint style="info" %}
If you get an error saying that the manifest cannot be found or about the requested image platform not matching the host platform, you are probably running on system architecture other than x64 arch. Since you are using a PR release you'll need to specify your platform with the --platform
flag.
For example, if you are running on M1 Mac, you would add --platform=linux/amd64
to the above command.
{% endhint %}
Or, with a custom Dockerfile:
FROM blockstack/stacks-signer:3.1.0.0.3.0
COPY signer-config.toml /config.toml
EXPOSE 30000
CMD ["stacks-signer", "run", "--config", "/config.toml"]
If you do not want to use Docker, you can alternatively run your stacks node as a binary.
Official binaries are available from the Stacks Core releases page on Github. Each release includes pre-built binaries. Download the ZIP file for your server’s architecture and decompress it. Inside of that folder is a stacks-signer
binary.
You can run the signer with the following command (be sure to replace ../signer-config.toml
with the actual path of your config file).
stacks-signer run --config ../signer-config.toml
To make sure your signer is running successfully, run docker ps
to list your running containers.
You should see something like this
Now check the logs of that container by running:
docker logs 877d478dfe7f
Be sure to replace the container ID at the end with your actual container ID.
You should see a message that says Signer spawned successfully. Waiting for messages to process...
.
You may also see a message indicating that your signer is not registered, like this:
WARN [1712003997.160121] [stacks-signer/src/runloop.rs:247] [signer_runloop] Signer is not registered for reward cycle 556. Waiting for confirmed registration...
This means your signer is running successfully. Your next step is to begin stacking in order to get your signer registered. First, if you haven't yet, get your Stacks node up and running following the instructions below and then proceed to How to Stack to get started stacking.
{% hint style="warning" %} Even after you Stack, you may still see a message that says:
Signer is not registered for the current reward cycle (557) or next reward cycle (558). Waiting for confirmed registration...
This is normal and means that you have stacked, but have not yet reach the prepare phase for your chosen reward cycle. Assuming you have met the stacking minimum, your signer will be picked up and registered during this prepare phase. {% endhint %}
While optional, we strongly recommend running your own Bitcoin node in order to optimize signer health and performance.
We have created guides for running both a full Bitcoin node and a pruned Bitcoin node you can follow.
Once your signer is running, the next step is to set up and run a Stacks node. It’s important to have the signer already running, because the node will not run unless it is able to send events to the signer.
Create a file called node-config.toml
. On the Sample Configuration Files page you'll find the full configuration file contents you'll need to add to this file.
The important aspects that you’ll need to change are:
working_dir
: a directory path where the node will persist dataauth_token
: an authentication token that your signer uses to authenticate certain requests to your node. This must match the value you used asauth_password
in the signer’s configuration.events_observer.endpoint
: This is the host (IP address and port) where your signer is configured to listen for events. An example string would be ”127.0.0.1:30000
” or ”my-signer.local:30000
”
If you are running your Stacks node on the primary testnet, it will be much faster to start with an archive of the chain state rather than syncing from genesis.
Archives can be found from https://archive.hiro.so. For the Stacks node testnet, the latest snapshot can be found at https://archive.hiro.so/testnet/stacks-blockchain/testnet-stacks-blockchain-latest.tar.gz. You can also browse all testnet snapshots.
You’ll want to download this on the same machine that will run the Stacks node. One way to do this is:
curl -# https://archive.hiro.so/testnet/stacks-blockchain/testnet-stacks-blockchain-latest.tar.gz -o stacks-snapshot.tar.gz
tar -zxvf stacks-snapshot.tar.gz
This will decompress the snapshot and create a xenon
folder in the same place that you downloaded the archive.
For the Stacks node to use this archive, you must specify working_dir
in your config file to be the place where you can find the xenon
folder.
For example:
- The snapshot is available at /Users/blah/xenon
- You will set working_dir to equal ”/Users/blah”
- Note that the string does not include the “xenon” part
You can run the Stacks node as a Docker container using the blockstack/stacks-core
image, currently on version 3.1.0.0.3. When running the Docker container, you’ll need to ensure a few things:
- The port configured for
p2p_bind
must be exposed to the internet - The port configured for
rpc_bind
must be accessible by your signer working_dir
needs to be on a volume with 500GB-1TB of available storage- You’ll need to include your
node-config.toml
file
An example for running the node’s Docker image with docker run is below. Be sure to run this from the same directory as your node-config.toml
file or change the STX_NODE_CONFIG
option.
IMG="blockstack/stacks-core"
VER="3.1.0.0.3"
STX_NODE_CONFIG="./node-config.toml"
docker run -d \
-v $STX_NODE_CONFIG:/config.toml \
-v /var/stacks \
-p 20443:20443 \
-p 20444:20444 \
-e RUST_BACKTRACE=full \
--name stacks-node \
$IMG:$VER \
stacks-node start \
--config /config.toml
Or, using a custom Dockerfile:
FROM blockstack/stacks-core:3.1.0.0.3
COPY node-config.toml /config.toml
EXPOSE 20444
EXPOSE 20443
CMD ["stacks-node", "start", "--config", "/config.toml"]
If when running your node you get a connection refused error that looks like this, you may need to point to Docker.
First, be sure that you have the proper entry point specified in your node-config.toml
file.
If you are inside a Docker container with default bridging mode, then localhost is not available, and you'll need to point to the Docker host.
If you do not want to use Docker, you can alternatively run your stacks node as a binary.
Official binaries are available from the Stacks Core releases page on Github. Each release includes pre-built binaries. Download the ZIP file for your server’s architecture and decompress it. Inside of that folder is a stacks-node
binary.
You can start the binary with:
./stacks-node start --config node-config.toml
Once you’ve started the Stacks node, you’ll see logs that start like this:
Mar 6 19:35:08.212848 INFO stacks-node 0.1.0
Mar 6 19:35:08.213084 INFO Loading config at path ./Stacks-config.toml
Mar 6 19:35:08.216674 INFO Registering event observer at: localhost:30000
Mar 6 19:35:08.221603 INFO Migrating sortition DB to the latest schema version
Mar 6 19:35:08.224082 INFO Migrating chainstate DB to the latest schema version
Mar 6 19:35:08.227404 INFO Start syncing Bitcoin headers, feel free to grab a cup of coffee, this can take a while
It’s important to ensure that you see the log message Registering event observer at XXX
with your signer’s endpoint included. Once Bitcoin headers have been synced, you may also be able to send a GET request to /v2/info
on your Stacks node’s RPC endpoint (port 20443 by default).
You may see a lot of messages while the node is syncing with Bitcoin blocks. You can check the How to Read the Signer Logs section if any of these concern you, but in all likelihood you can ignore any messages until Bitcoin blocks are synced.
{% hint style="info" %} For more information on the relationship between stacking and signing and how stacking works, check out the Stack STX guide. {% endhint %}
As a signer you’ll need to fund and manage two Stacks accounts:
- A “pool operator” wallet, which commits delegated STX to your signer
- Your signer’s wallet
{% hint style="warning" %} For testing, make sure that you are using testnet, and not mainnet, STX. You can change network settings within your wallet, and testnet STX can be requested from a faucet. {% endhint %}
You can set up your pool operator wallet using any Stacks wallet, such as Leather or Xverse. You may choose to generate a new account or use an existing one. If you prefer to use a hardware wallet, Leather has support for the Ledger hardware wallet.
Once your wallet has been created, you’ll need to fund it with enough STX to cover transaction fees. For testnet, you can use a faucet exposed by the Stacks Explorer.
Finally, share this wallet’s STX address with the parties that will be delegating STX to you. For improved user experience, you might want to use the helper contract that allows to specify a btc address for stackers (pox4-pools) and to add your pool to lockstacks.com.