Setup for Windows
Setup for Windows
Welcome to the step-by-step guide on installing the GPU Hosts on your Windows system. This documentation has been designed to make the installation process straightforward and efficient, even for those who aren't tech-savvy. Follow along, and you'll have your GPU Hosts up and running in no time.
- Install Ubuntu 22.04 on WSL2
- Install Docker
- Install NVIDIA drivers and container toolkit
- Install Podman v4
- Run the GPU Hosts and register for Nosana Grid
Guide: Installing Ubuntu 22.04 on WSL2
For Windows users, it's essential to set up Ubuntu 22.04 specifically on WSL2.
Warning
Ensure you're installing Ubuntu 22.04 on WSL2. Unfortunately, Ubuntu 20.04 is not compatible with WSL2.
For detailed instructions on how to install WSL2 and run Ubuntu 22.04, follow the tutorial linked below:
Once installed, you can verify your WSL2 Ubuntu version by running the following command:
lsb_release -a
Please confirm that you have installed version 22.04.
WSL2 Config
WSL2 only allocates half of the system RAM. So it's common for a 32GB PC to run a node then the operator is surprised their jobs fail since their node only had 16GB when they run with something like a 24GB RTX 4090.
Simple way to increase available RAMs for node on windows:
- Shut down WSL2.
- Open File Explorer, navigate to C:\Users\YourWindowsUsername.
- Create ".wslconfig"(use Notepad, ensure no.txtextension, Save As as All files. I named with " " it helps for windows not to add.txtextension):
- Copy the following text into file:
[wsl2]
memory=58GB     # Adjust to ~90% of your total RAM (e.g., 58GB for 64GB system)
processors=16   # Match your CPU cores (e.g., 16 for an 16-core CPU)
swap=16GB       # Extra swap for memory overflow, once it runs out of RAM memory it borrows from SSD
- Save file and Restart WSL2. Check available storage with:
free -h
Docker
To ensure a successful setup, follow these steps to install and configure Docker:
- Install Docker Desktop with the WSL2 backend by visiting this link: Install Docker Desktop with WSL2 backend. 
- After installation, make sure Docker is added to its own user group. 
NVIDIA
To fully utilize the GPU on the grid, we will need to install both the NVIDIA drivers and NVIDIA's CUDA Toolkit.
NVIDIA Driver Installation Guide
To use NVIDIA drivers, download and install the appropriate driver from the official NVIDIA website: NVIDIA Driver Downloads.
To verify if the drivers are correctly installed, open a terminal and run the following command:
nvidia-smi
If the drivers are correctly installed, you should see detailed information about your GPU, similar to the following example output:
+-----------------------------------------------------------------------------+
| NVIDIA-SMI 525.54       Driver Version: 526.56       CUDA Version: 12.0     |
|-------------------------------+----------------------+----------------------+
| GPU  Name        Persistence-M| Bus-Id        Disp.A | Volatile Uncorr. ECC |
| Fan  Temp  Perf  Pwr:Usage/Cap|         Memory-Usage | GPU-Util  Compute M. |
|                               |                      |               MIG M. |
|===============================+======================+======================|
|   0  NVIDIA GeForce ...  On   | 00000000:01:00.0 Off |                  N/A |
| N/A   43C    P5     9W /  N/A |      0MiB /  4096MiB |      0%      Default |
|                               |                      |                  N/A |
+-------------------------------+----------------------+----------------------+
+-----------------------------------------------------------------------------+
| Processes:                                                                  |
|  GPU   GI   CI        PID   Type   Process name                  GPU Memory |
|        ID   ID                                                   Usage      |
|=============================================================================|
|  No running processes found                                                 |
+-----------------------------------------------------------------------------+
These commands will help you generate the necessary configuration file and verify the CDI support.
Install the NVIDIA Container Toolkit
To install the NVIDIA Container Toolkit (nvidia-ctk), run the following commands:
curl -fsSL https://nvidia.github.io/libnvidia-container/gpgkey | sudo gpg --dearmor -o /usr/share/keyrings/nvidia-container-toolkit-keyring.gpg \
  && curl -s -L https://nvidia.github.io/libnvidia-container/stable/deb/nvidia-container-toolkit.list | \
    sed 's#deb https://#deb [signed-by=/usr/share/keyrings/nvidia-container-toolkit-keyring.gpg] https://#g' | \
    sudo tee /etc/apt/sources.list.d/nvidia-container-toolkit.list \
  && \
    sudo apt-get update
Then we can install the NVIDIA Container Toolkit package:
sudo apt-get install -y nvidia-container-toolkit
Configure the NVIDIA Container Toolkit
For configuring the NVIDIA Container Toolkit to run Podman v4 natively on WSL2 (as Podman in Docker is not supported on WSL2), please follow the instructions for CDI configuration. You can find these instructions at https://docs.nvidia.com/datacenter/cloud-native/container-toolkit/latest/cdi-support.html.
Once you have completed the configuration, run the following commands:
sudo nvidia-ctk cdi generate --output=/etc/cdi/nvidia.yaml
nvidia-ctk cdi list
Podman
The GPU Hosts connects to Podman and runs your containers inside of it. On WSL2, you'll need to natively install Podman >v4.1:
echo "deb https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/unstable/xUbuntu_22.04/ /" | sudo tee /etc/apt/sources.list.d/devel:kubic:libcontainers:unstable.list
curl -fsSL https://download.opensuse.org/repositories/devel:/kubic:/libcontainers:/unstable/xUbuntu_22.04/Release.key | sudo gpg --dearmor | sudo tee /etc/apt/trusted.gpg.d/devel_kubic_libcontainers_unstable.gpg > /dev/null
sudo apt update
sudo apt install podman
Check if you have Podman version 4 installed and if you have GPU support:
podman --version
podman run --rm --device nvidia.com/gpu=all --security-opt=label=disable ubuntu nvidia-smi -L
If this doesn't work, make sure you have the NVIDIA drivers installed and the nvidia-ctk installed and configured
If you see Error: container create failed (no logs from conmon)... when running the command, follow the steps here to resolve issue
Join the Grid
With just a single command in your command line, you can easily set up a GPU Hosts on your machine. Simply run the following command:
bash <(wget -qO- https://nosana.com/start.sh)
Please note that this script has certain requirements and is specifically designed to run without the need for sudo privileges. It's crucial to exercise caution when running any script from the internet with sudo privileges. Even in this case, it's advisable to thoroughly review the script before executing it on your system. You can review the script here: https://nosana.com/start.sh
The script performs a series of tests to verify the successful completion of the previous steps outlined in the guide.
You will see your node's information displayed in the following format.
  _   _
 | \ | | ___  ___  __ _ _ __   __ _
 |  \| |/ _ \/ __|/ _` | '_ \ / _` |
 | |\  | (_) \__ \ (_| | | | | (_| |
 |_| \_|\___/|___/\__,_|_| |_|\__,_|
Reading keypair from ~/.nosana/nosana_key.json
Network:     mainnet
Wallet:      <NODE_ADDRESS>
SOL balance: 0E-9 SOL
NOS balance: 0 NOS
Provider:     podman
Nosana Grid Registration Instructions
When running the script it'll ask for some information: email, Discord & Twitter/X handle (optional). After filling in the information and agreeing to the terms & conditions, a benchmark will start. In this benchmark we will check the hardware of your node.
Warning
To find your Node's Solana key, navigate to ~/.nosana/nosana_key.json. It is essential to back up this file to ensure its safety.
Advanced (optional)
Run Podman API
This command can be used to start Podman service with a socket file, so our GPU Hosts can use that socket to reach Podman service.
 This is also already done by the start.sh script in the final step, so this step is optional:
mkdir -p $HOME/.nosana/podman
{ podman system service --time 0 unix://$HOME/.nosana/podman/podman.sock & } 2> podman.log
Launching the GPU Hosts with Custom Parameters
You can manually launch the GPU Hosts to modify certain parameters:
- Use the --podmanparameter to direct to your Podman service socket if it's located elsewhere.
- Use --volumeto map your Solana key to/root/.nosana/nosana_key.jsonwithin the Docker container if you wish to use your own key.
docker run \
      --pull=always \
      --network host  \
      --interactive -t \
      --volume ~/.config/solana/id.json:/root/.nosana/nosana_key.json \
      --volume ~/.nosana/podman:/root/.nosana/podman:ro \
      nosana/nosana-cli:latest \
         node join \
         --podman /root/.nosana/podman/podman.sock
Troubleshoot
If you have questions or when you have error messages, please take a look at our Troubleshoot Guide or join our Discord for help.