Skip to content

Latest commit

 

History

History
135 lines (85 loc) · 4.29 KB

README.md

File metadata and controls

135 lines (85 loc) · 4.29 KB

Use Docker to Run a Sui Full node Locally

Follow the steps in this Readme to install and configure a Sui Full node for testing locally using Docker. The instructions were validated on the following operating system/processor combinations:

  • Linux/AMD64
  • Darwin/AMD64
  • Darwin/ARM64

Prerequisites

Configure Sui Full node

Download the latest version of the Sui Full node configuration file fullnode-template.yaml. Use the following command to download the file:

wget https://github.com/MystenLabs/sui/raw/main/crates/sui-config/data/fullnode-template.yaml

Download the Sui genesis blob

The genesis blob contains the information that defined the Sui network configuration. Before you can start the Full node, you need to download the most recent file to ensure compatibility with the version of Sui you use. Use the following command to download the genesis.blob from the devnet branch of the Sui repository:

wget https://github.com/MystenLabs/sui-genesis/raw/main/devnet/genesis.blob

Start your Sui Full node

Run the following command to start the Sui fullnode in Docker:

docker compose up

Important: The commands in this document assume you use Docker Compose V2. The docker compose command uses a dash (docker-compose) in Docker Compose V1. If you use Docker Compose V1, replace the space in each docker compose command with a dash (docker-compose). For more information, see Docker Compose V2.

Test the Sui Full node

After the Full node starts you can test the JSON-RPC interfaces.

View activity on your local Full node with Sui Explorer

Sui Explorer supports connecting to a local network. To view activity on your local Full node, open the URL: https://explorer.sui.io/?network=local.

You can also change the network that Sui Explorer connects to by select it in the Sui Explorer interface.

Stop the Full node

Run the following command to stop the Full node when you finish using it:

docker compose stop

Troubleshooting

If you encounter errors or your Full node stops working, run the commands in the following section to resolve the issue.

Start the Full node in detached mode

First, try starting the Full node in detached mode:

docker compose up -d

Reset the environment

If you continue to see issues, stop the Full node (docker compose stop) and delete the Docker container and volume. Then run the following command to start a new instance of the Full node using the same genesis blob.

docker compose down --volumes

Stats (CPU/MEM USAGE %)

To view usage details for the Full node running in Docker, run the following command:

docker stats

This command shows a live data stream of the Docker container resource usage, such as CPU and memory. To view data for all containers, use the following command:

docker stats -a

Inspect the state of a running Full node

Get the running container ID:

docker ps

Connect to a bash shell inside the container:

docker exec -it $CONTAINER_ID /bin/bash

Inspect the database:

ls -la suidb/

Investigate local RPC connectivity issues

Update the json-rpc-address in the Full node config to listen on all addresses:

sed -i 's/127.0.0.1/0.0.0.0/' fullnode-template.yaml
-json-rpc-address: "127.0.0.1:9000"
+json-rpc-address: "0.0.0.0:9000"

Install wget and curl

Download each package. For example, on macOS use homebrew:

brew install wget curl

Learn more about Sui

Learn more about building and running a Full node from source code

Learn more about Docker Compose