Lotus Miner Setup
This is a step by step guide on how to set up a lotus miner in calibnet. Some of the steps are specific to the hardware and configuration used in this setup and might not be applicable for everyone. Please follow the documentation to set up your miner and use this guide only as a reference point.
Setup details
Below are the details of the physical servers used in this tutorial. One of these machines will run a lotus node and other will be used to run a lotus-miner node.
Machine One
- CPU: 2 x Intel(R) Xeon(R) Gold 6242 CPU @ 2.80GHz
- RAM: 502 GiB
- GPU: 4 x Quadro RTX 6000
- Process: Lotus Node, Seal Worker
- OS: Ubuntu
- Private IP: x.x.x.x
- Public IP: A.A.A.A
Machine Two
- CPU: 2 x Intel(R) Xeon(R) Gold 6242 CPU @ 2.80GHz
- RAM: 502 GiB
- GPU: 4 x Quadro RTX 6000
- Process: Lotus Miner(Seal worker)
- OS: Ubuntu
- Private IP: y.y.y.y
- Public IP: B.B.B.B
All lotus processes will run as a non-root user. Please make sure to open relevant ports in your firewall to allow connections.
Lotus node setup
This section will cover the installation, configuration and starting a lotus node to be used in the tutorial.
Installation
We have bundled all the install steps into the below code snippets so you can just copy and paste them into your terminal. If you would prefer to run each command step by step, take a look at the Installation guide.
FFI_USE_CUDA=1
variable forces the use of CUDA architecture instead of OpenCL for Nvidia cards.RUST_GPU_TOOLS_CUSTOM_GPU
variable need to be set after driver 475+ due to a change in naming convention.sudo apt install mesa-opencl-icd ocl-icd-opencl-dev gcc git jq pkg-config curl clang build-essential hwloc libhwloc-dev wget -y && sudo apt upgrade -y curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
Follow the prompts to install Rust, and then run these commands:
wget -c https://golang.org/dl/go1.19.12.linux-amd64.tar.gz -O - | sudo tar -xz -C /usr/local echo 'export PATH=$PATH:/usr/local/go/bin' >> ~/.bashrc && source ~/.bashrc git clone https://github.com/filecoin-project/lotus.git cd lotus/ LATEST_RELEASE=$(git tag -l 'v*' | sort -V -r | head -n 1) # Finds the latest Lotus Node release git checkout $LATEST_RELEASE export CGO_CFLAGS_ALLOW="-D__BLST_PORTABLE__" export CGO_CFLAGS="-D__BLST_PORTABLE__" export FFI_BUILD_FROM_SOURCE=1 export RUSTFLAGS="-C target-cpu=native -g" export FFI_USE_CUDA=1 export RUST_GPU_TOOLS_CUSTOM_GPU="Quadro RTX 6000:4608" make clean calibnet ./lotus --version
Add sufficient swap to the machines based on the hardware requirements guide.
Configuration
Initialize the lotus node and wait for the sync to complete. If you are configuring the miner for mainnet then, please import a snapshot and wait for the lotus node to get synced:
export GOLOG_OUTPUT=file >> ~/.bashrc export GOLOG_FILE="$HOME/miner.log" >> ~/.bashrc && source ~/.bashrc lotus daemon &
Configure lotus node to allow remote API access. Please do not listen on a public IP as it will allow anyone from the internet to be able to connect to this node. Ideally, use a private IP and in case there is no private IP available, please ensure that the firewall is configured to reject all packets except from miner/market APIs for security
[API] # Binding address for the Lotus API # # type: string # env var: LOTUS_API_LISTENADDRESS ListenAddress = "/ip4/x.x.x.x/tcp/1234/http" # type: string # env var: LOTUS_API_REMOTELISTENADDRESS #RemoteListenAddress = "x.x.x.x:1234" # type: Duration # env var: LOTUS_API_TIMEOUT # Timeout = "30s"
Restart the Lotus node for the changes to take effect.
Generate an API token for the miner:
lotus auth create-token --perm admin
Verify that the lotus node is in sync and that lotus is listening on the specified port:
telnet x.x.x.x 1234
Setup wallets for the miner
Create wallets for the lotus-miner on the Lotus node machine:
lotus wallet new bls lotus wallet new bls
Send some FIL to the owner wallet from the calibnet faucet. For the mainnet, the user can send fils from an exchange or other sources.
Send some fils from the owner wallet to the worker wallet:
lotus send --from <owner address> <worker address> 10
Verify that fils are present in both wallets:
lotus wallet list
Lotus miner setup
This section will cover the installation, configuration, and how to start the lotus-miner node.
Installation
We have bundled all the install steps into the below code snippets so you can just copy and paste them into your terminal. If you would prefer to run each command step by step, take a look at the Installation guide.
FFI_USE_CUDA=1
variable forces the use of CUDA architecture instead of OpenCL for Nvidia cards.RUST_GPU_TOOLS_CUSTOM_GPU
variable need to be set after driver 475+ due to a change in naming convention:sudo apt install mesa-opencl-icd ocl-icd-opencl-dev gcc git jq pkg-config curl clang build-essential hwloc libhwloc-dev wget -y && sudo apt upgrade -y curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
Follow the prompts to install Rust, and then run these commands:
wget -c https://golang.org/dl/go1.19.12.linux-amd64.tar.gz -O - | sudo tar -xz -C /usr/local echo 'export PATH=$PATH:/usr/local/go/bin' >> ~/.bashrc && source ~/.bashrc git clone https://github.com/filecoin-project/lotus.git cd lotus/ LATEST_RELEASE=$(git tag -l 'v*' | sort -V -r | head -n 1) # Finds the latest Lotus Miner release git checkout $LATEST_RELEASE export CGO_CFLAGS_ALLOW="-D__BLST_PORTABLE__" export CGO_CFLAGS="-D__BLST_PORTABLE__" export FFI_BUILD_FROM_SOURCE=1 export RUSTFLAGS="-C target-cpu=native -g" export FFI_USE_CUDA=1 export RUST_GPU_TOOLS_CUSTOM_GPU="Quadro RTX 6000:4608" make clean calibnet ./lotus --version
Add sufficient swap to the machines based on the hardware requirements guide.
On the miner machines, create directories to store the cache. Make sure these directories are on a fast NVME disk. Otherwise, it will slow down your miner:
mkdir ~/parent_cache mkdir ~/parameter_cache
Setup
Add the following variables to the
~/.bashrc
file:# See https://github.com/filecoin-project/rust-fil-proofs/ export FIL_PROOFS_USE_GPU_COLUMN_BUILDER=1 # precommit2 GPU acceleration export FIL_PROOFS_USE_GPU_TREE_BUILDER=1 # The following increases speed of PreCommit1 at the cost of using a full # CPU Core-Complex rather than a single core. Should be used with CPU affinities set! # See https://github.com/filecoin-project/rust-fil-proofs/ and the seal workers guide. export FIL_PROOFS_USE_MULTICORE_SDR=1 export FULLNODE_API_INFO=<TOKEN>:/ip4/x.x.x.x/tcp/1234/http export FIL_PROOFS_PARAMETER_CACHE=/home/miner/param_cache # > 100GiB! export FIL_PROOFS_PARENT_CACHE=/home/miner/parent_cache # > 50GiB! export FFI_USE_CUDA=1 export RUST_GPU_TOOLS_CUSTOM_GPU="Quadro RTX 6000:4608" export LOTUS_MINER_PATH=~/.lotusminer export GOLOG_OUTPUT=file export GOLOG_FILE="$HOME/miner.log"
Now
source
the file to load these variable to the current shell.source ~/.bashrc
Download parameters:
lotus-miner fetch-params 32GiB lotus-miner fetch-params 64GiB
Initialize the miner:
lotus-miner init --owner=<address> --worker=<address> --no-local-storage
Start the miner
lotus-miner run
Lotus miner configuration
Add storage for sealing, as well as permanent storage for the sectors:
mkdir ~/storage mkdir ~/tmp
Please make sure that ~/tmp directory is backed by a fast disk like NVME.
lotus-miner storage attach --init --seal ~/tmp lotus-miner storage attach --init --store ~/storage lotus-miner storage list
Enable remote API access on the lotus-miner to allow the remote seal-workers connection to the miner:
[API] # Binding address for the miner API ListenAddress = "/ip4/y.y.y.y/tcp/2345/http" # This should be set to the miner API address as seen externally RemoteListenAddress = "y.y.y.y:2345" # General network timeout value Timeout = "30s"
Restart the
lotus-miner
process.Verify that all the resources are visible on the miner and are ready to use:
lotus-miner sealing workers > Worker xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx, host miner-host > CPU: [ ] 0/64 core(s) in use > RAM: [|||||| ] 9% 46.38 GiB/502.6 GiB > VMEM: [|| ] 3% 46.38 GiB/1.4 TiB > GPU: [ ] 0% 0.00/4 gpu(s) in use > GPU: Quadro RTX 6000, not used > GPU: Quadro RTX 6000, not used > GPU: Quadro RTX 6000, not used > GPU: Quadro RTX 6000, not used
Now the miner is ready to start sealing.
Generate auth token for seal-worker
Generate the JWT token for the seal workers. This token can be used to add additional seal-workers to speed up the sealing process.
lotus-miner auth api-info --perm admin