Assign GPU to the Node
How to run multiple nodes on a single device with multiple GPUs
If you have multiple GPUs in a single computer, you can optimize performance by starting multiple nodes on the computer and assigning each GPU to a different node.
To enable GPU assignment, use the Docker version of Crynux Node. For a guide on the basics of starting a Crynux Node as a Docker container, please refer to the tutorial below:
Start a Node - DockerFind the ID of the specific GPU
If you want to assign a specific GPU to a node, you must find the ID of the GPU first. This can be done using the nvidia-smi toolkit. Start a terminal and run the following command:
$ nvidia-smiAnd you will get the output similar to the following:

Find the ID as highlighted in the image above. In this case, we have a single GPU installed in the computer, the ID of the GPU is 0.
GPU assignment using Docker Compose
In the docker-compose.yml file, find the following section:
And add another line below:
GPU assignment using command line
The GPU id could also be given to the container in the starting command. If you are starting the container using the following command before:
You could change it to:
The change is on the --gpus argument, from all, which provides all the GPUs to the container, to '"device=0"', which provides only the GPU with id 0.
Start multiple containers for each of the GPUs on the same computer
For each of the GPUs, follow the tutorial to clone the docker compose project:
Start a Node - DockerFor example, if you have 3 GPUs on the same computer, just clone the docker compose project 3 times, after renaming the folders, you have 3 working folders locally:
In each of the working folders, find the docker-compose.yml file, and edit the content:
1. Change the name, service name and the container name, so that every container is using a different one:
from:
to:
2. Add a line to specify the GPU id as mentioned above:
3. Change the exposing port. So that every container is using a different port:
from:
to:
for the second container. And use 7414 for the third one.
The complete docker-compose.yml files for each of the 3 containers is shown below:
Node 1
crynux_node_docker_compose_1/docker-compose.yml
Node 2
crynux_node_docker_compose_2/docker-compose.yml
Node 3
crynux_node_docker_compose_3/docker-compose.yml
Finally, in each of the folders, run the docker compose up command to start the container:
Last updated