Install on Linux via Docker¶
Docker is an open source application container engine. Using docker, you can not only isolate the installation and use of paddlepaddle from the system environment, but also share GPU, network and other resources with the host. In the following Docker installation and use process, a specific version of PaddlePaddle has been installed in docker.
Environment preparation¶
Currently supported system types, please see Installation instruction, please note that Docker is not currently supported in CentOS 6
On the local host Install Docker
To enable GPU support on Linux, please Install NVIDIA Container Toolkit
Python version in the image is 3.10
Installation steps¶
1. Pull PaddlePaddle image¶
For domestic users, when downloading docker is slow due to network problems, you can use the mirror provided by Baidu:
CPU version of PaddlePaddle:
docker pull registry.baidubce.com/paddlepaddle/paddle:2.6.1
CPU version of PaddlePaddle, and the image is pre-installed with jupyter:
docker pull registry.baidubce.com/paddlepaddle/paddle:2.6.1-jupyter
GPU version of PaddlePaddle(Latest version of gpu image is recommended, and make sure NVIDIA Container Toolkit is installed successfully):
docker pull registry.baidubce.com/paddlepaddle/paddle:2.6.1-gpu-cuda11.2-cudnn8.2-trt8.0
docker pull registry.baidubce.com/paddlepaddle/paddle:2.6.1-gpu-cuda11.7-cudnn8.4-trt8.4
docker pull registry.baidubce.com/paddlepaddle/paddle:2.6.1-gpu-cuda12.0-cudnn8.9-trt8.6
If your machine is not in mainland China, you can pull the image directly from DockerHub:
CPU version of PaddlePaddle:
docker pull paddlepaddle/paddle:2.6.1
CPU version of PaddlePaddle, and the image is pre-installed with jupyter:
docker pull paddlepaddle/paddle:2.6.1-jupyter
GPU version of PaddlePaddle(Latest version of gpu image is recommended, and make sure NVIDIA Container Toolkit is installed successfully):
docker pull paddlepaddle/paddle:2.6.1-gpu-cuda11.2-cudnn8.2-trt8.0
docker pull paddlepaddle/paddle:2.6.1-gpu-cuda11.7-cudnn8.4-trt8.4
docker pull paddlepaddle/paddle:2.6.1-gpu-cuda12.0-cudnn8.9-trt8.6
You can see DockerHub to get more images.
2. Build and enter Docker container¶
Use CPU version of PaddlePaddle:
docker run --name paddle_docker -it -v $PWD:/paddle registry.baidubce.com/paddlepaddle/paddle:2.6.1 /bin/bash
--name paddle_docker
: set name of Docker,paddle_docker
is name of docker you set;-it
: The parameter indicates that the container has been operated interactively with the local machine;-v $PWD:/paddle
: Specifies to mount the current path of the host (PWD variable in Linux will expand to the absolute path of the current path) to the /paddle directory inside the container;registry.baidubce.com/paddlepaddle/paddle:2.6.1
: Specify the name of the image to be used. You can view it through the ‘docker images’ command. /bin/Bash is the command to be executed in Docker
Use GPU version of PaddlePaddle:
docker run --gpus all --name paddle_docker -v $PWD:/paddle --network=host -it registry.baidubce.com/paddlepaddle/paddle:latest-dev-cuda12.0-cudnn8.9-trt8.6-gcc12.2 /bin/bash
--gpus all
: gpu resources can be used in Docker container;--name paddle_docker
: set name of Docker,paddle_docker
is name of docker you set;-it
: The parameter indicates that the container has been operated interactively with the local machine;-v $PWD:/paddle
: Specifies to mount the current path of the host (PWD variable in Linux will expand to the absolute path of the current path) to the /paddle directory inside the container;registry.baidubce.com/paddlepaddle/paddle:latest-dev-cuda12.0-cudnn8.9-trt8.6-gcc12.2
: Specify the name of the image to be used. You can view it through the ‘docker images’ command. /bin/Bash is the command to be executed in Docker
Use CPU version of PaddlePaddle with jupyter:
mkdir ./jupyter_docker
chmod 777 ./jupyter_docker
cd ./jupyter_docker
docker run -p 80:80 --rm --env USER_PASSWD="password you set" -v $PWD:/home/paddle registry.baidubce.com/paddlepaddle/paddle:2.6.1-jupyter
--rm
: Delete the container after closing it;--env USER_PASSWD="password you set"
: Set the login password for jupyter,password you set
is the password you set;-v $PWD:/home/paddle
: Specifies to mount the current path (the PWD variable will be expanded to the absolute path of the current path) to the /home/paddle directory inside the container;registry.baidubce.com/paddlepaddle/paddle:2.6.1-jupyter
: Specify the name of the image to be used, you can view it through thedocker images
command
Now you have successfully used Docker to install PaddlePaddle. For more information about using Docker, seeDocker official documents
Introduction to mirror images¶
Mirror source | Mirror description |
---|---|
registry.baidubce.com/paddlepaddle/paddle:2.6.1 | CPU image with 2.6.1 version of paddle installed |
registry.baidubce.com/paddlepaddle/paddle:2.6.1-jupyter | CPU image of paddle version 2.6.1 is installed, and jupyter is pre-installed in the image. Start the docker to run the jupyter service |
registry.baidubce.com/paddlepaddle/paddle:2.6.1-gpu-cuda12.0-cudnn8.9-trt8.6 | GPU image of paddle version 2.6.1 is installed, cuda version is 12.0, cudnn version is 8.9, trt version is 8.6 |
registry.baidubce.com/paddlepaddle/paddle:2.6.1-gpu-cuda11.7-cudnn8.4-trt8.4 | GPU image of paddle version 2.6.1 is installed, cuda version is 11.7, cudnn version is 8.4, trt version is 8.4 |
registry.baidubce.com/paddlepaddle/paddle:2.6.1-gpu-cuda11.2-cudnn8.2-trt8.0 | GPU image of paddle version 2.6.1 is installed, cuda version is 11.2, cudnn version is 8.2, trt version is 8.0 |
You can find the docker mirroring of the published versions of PaddlePaddle in DockerHub.
Supplement¶
When you need to enter the docker container for the second time, use the following command:
Container created before startup
docker start <Name of container>
Enter the starting container
docker attach <Name of container>
If you are a newcomer to Docker, you can refer to the materials on the Internet for learning, such as Docker tutorial
How to uninstall¶
After entering the Docker container, execute the following command:
CPU version of PaddlePaddle:
pip uninstall paddlepaddle
GPU version of PaddlePaddle:
pip uninstall paddlepaddle-gpu
Or delete the docker container directly through docker rm <Name of container>