Getting Started

Run a Fiber Node

Learn how to run a Testnet node on your local machine

Overview

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.

Prerequisites

  • Git (if building from source)
  • Rust and Cargo (if building from source)
  • Basic understanding of command line operations
  • ckb-cli tool for key management

Building and Setting Up Your Node

1. Obtain the FNN Binary

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.

2. Create Node Directory

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

3. Set Up Node Keys

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

4. Start the Node

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.

Version Compatibility and Upgrades

FNN is under active development, and protocol/storage format changes may occur between versions. Here’s how to handle upgrades:

Safe Upgrade Process

  1. Close all active channels before upgrading:

  2. Stop the node and clean the storage:

rm -rf /folder-to/my-fnn/fiber/store
  1. Update the node:
    • Replace the FNN binary with the new version
    • Start the node again

Storage Migration (Optional)

If you want to preserve channel states during an upgrade:

  1. Stop your node
  2. Back up your data:
cp -r /folder-to/my-fnn/fiber/store /folder-to/my-fnn/fiber/store.backup
  1. Run the migration tool:
fnn-migrate -p /folder-to/my-fnn/fiber/store
  1. Update and restart:
    • Replace the FNN binary
    • Start your node

Next Steps

Once your node is running, you can:

  • Connect to other peers
  • Open payment channels
  • Send and receive payments
  • Explore more RPC methods

Check out the Basic Transfer Example guide for a practical example of using your node.