Getting Started
Learn how to run a Testnet node on your local machine
This guide walks you through the process of setting up and running a Fiber Network Node (FNN) on the Testnet. You’ll learn how to build the node from source or use a pre-built binary, configure it properly, and start it up.
You can either download a pre-built binary from the Fiber GitHub Releases page or build it from source:
git clone https://github.com/nervosnetwork/fiber.git
cd fiber
cargo build --release
This document used the v0.4.0 binary throughout the guide.
Create a dedicated directory for your node and copy the necessary files:
mkdir /folder-to/my-fnn
# If using released binary, replace target/release/fnn with the path to your downloaded binary
cp target/release/fnn /folder-to/my-fnn
cp config/testnet/config.yml /folder-to/my-fnn
cd /folder-to/my-fnn
FNN includes built-in wallet functionality for signing funding transactions. You’ll need to create or import a private key:
mkdir ckb
# Export an existing key using ckb-cli
ckb-cli account export --lock-arg <lock_arg> --extended-privkey-path ./ckb/exported-key
# Extract just the private key (FNN only needs this part)
head -n 1 ./ckb/exported-key > ./ckb/key
Launch your node with logging enabled:
RUST_LOG=info ./fnn -c config.yml -d .
The node will start syncing with the Testnet and output logs to the console. You can redirect the output to a file if needed.
FNN is under active development, and protocol/storage format changes may occur between versions. Here’s how to handle upgrades:
Close all active channels before upgrading:
Stop the node and clean the storage:
rm -rf /folder-to/my-fnn/fiber/store
If you want to preserve channel states during an upgrade:
cp -r /folder-to/my-fnn/fiber/store /folder-to/my-fnn/fiber/store.backup
fnn-migrate -p /folder-to/my-fnn/fiber/store
Once your node is running, you can:
Check out the Basic Transfer Example guide for a practical example of using your node.