40
SpaCy 3 on a Google Cloud Compute Instance to train a NER Transformer Model
Here you will find a step by step guide (last tested and working July 2021) on how to install and use Spacy 3.0 (and Cupy) on a Google Cloud GPU powered instance. I wrote this article in order to spare others whole days testing and installing packages. I've already wasted them, why should you? ;)
I used this architecture to train a NER Transformer Model.
Softwares versions:
- cuda v11.2
- spacy v3.0
Create a virtual machine instance: is a google cloud virtual machine with this setup
GPU machine
Serie: A2
Machine: a2-highgpu-1g
GPU: 1 x NVIDIA Tesla a100
Image: Debian GNU/Linux 10 (buster)
WARNING: you must modify the standard disk space: 10gb are not enough (at least for my needs). I used 30gb.
Connect via ssh to the created virtual machine, update the system and install some useful packages with these commands
sudo apt-get update && sudo apt-get upgrade
sudo apt-get -y install pciutils software-properties-common wget g++ freeglut3-dev build-essential libx11-dev libxmu-dev libxi-dev libglu1-mesa libglu1-mesa-dev
Check if your gpu is cuda enabled. If not there is probably a problem with your architecture you need to investigate further.
You should have at least one positive output.
lspci | grep -i nvidia
Let's clean eventually previous installation and packages:
sudo apt-get purge nvidia*
sudo apt remove nvidia-*
sudo rm /etc/apt/sources.list.d/cuda*
sudo apt-get autoremove && sudo apt-get autoclean
sudo rm -rf /usr/local/cuda*
gcc compiler is required for development using the cuda toolkit. to verify the version of gcc installed enter
gcc --version
if not present, install it
sudo apt-get -y install gcc
Install kernel headers needed by Nvidia drivers:
sudo apt-get -y install linux-headers-4.19.0-16-cloud-amd64
Now download and install the latest nvidia driver for Debian 10. This is the most up-to-date drivers at the time I'm writing this article: https://www.nvidia.com/Download/driverResults.aspx/173142/en-us. If you decide to install more up-to-date drivers (which I recommend) you'll also probably need to accordingly adjust something else from this guide.
If you want to look for some other update / architectures: https://www.nvidia.com/Download/index.aspx?lang=en-us
# download drivers
wget https://us.download.nvidia.com/tesla/460.73.01/NVIDIA-Linux-x86_64-460.73.01.run
# make it executable
chmod u+x NVIDIA-Linux-x86_64-460.73.01.run
# install the drivers
sudo ./NVIDIA-Linux-x86_64-460.73.01.run
When asked, do not install 32-bit compatibilty packages.
Check that the drivers have been correctly installed with:
nvidia-smi
The ouput should be now something like this. If the command cannot find any GPU, there is something wrong (check for new drivers et similia) and continuing in this guide will be pointless:
Install NVIDIA CUDA 11.3 toolkit packages for Debian 10. For other installations (not considered in this article) please refer to this useful NVIDIA link: https://developer.nvidia.com/cuda-downloads
sudo apt-key adv --fetch-keys https://developer.download.nvidia.com/compute/cuda/repos/debian10/x86_64/7fa2af80.pub
sudo add-apt-repository "deb https://developer.download.nvidia.com/compute/cuda/repos/debian10/x86_64/ /"
sudo add-apt-repository contrib
sudo apt-get update
sudo apt-get -y install cuda-11-2
If asked to remove one NVIDIA package proceed with yes.
Check that the drivers are still correctly installed with:
nvidia-smi
output should be like the previous one.
We will now create a python virtualenv, install spacy and check if spacy can access the GPU.
# install useful package
sudo apt-get -y install python3-venv
# creates venv
python3 -m venv myvenv
# activate it
source myvenv/bin/activate
# upgrade pip
pip install --upgrade pip
# install spacy
pip install -U spacy
# download the trf model
python -m spacy download en_core_web_trf
# install other pip packages and dependencies
pip install torch==1.7.1+cu110 torchvision==0.8.2+cu110 torchaudio==0.7.2 -f https://download.pytorch.org/whl/torch_stable.html
# point to the correct cuda folder
export CUDA_PATH="/usr/local/cuda-11"
# install spacy transformers info
pip install -U spacy[cuda113,transformers]
# and install the correct version of cupy
# here more info: https://docs.cupy.dev/en/stable/install.html#installing-cupy
pip install cupy-cuda113
Test spacy and cupy: run python and the following commands
python
>>> import spacy
>>> spacy.require_gpu()
the output must be simply
True
Another test you can do to be absolutely sure everything is correctly installed, always inside a python console:
>>> import cupy
>>> a = cupy.zeros((1,1))
this commands should give no output at all. If it does, it will probably be an explanatory error/exception.
You are now ready and you can use your GPU inside spacy or any other systems using cupy.
Feel free (and please do it) to reach me out for any error you may find or any question you may have.
This article is also a gist here: https://gist.github.com/DavidGerva/86bba9a23e4376e4303d3ca02a422612
This guide is an adaptation to my needs and "today" of this material I found online and I tested over and over again till this working solution: should work "as is".
40