This tutorial covers how to create a Custom Container (docker image) to train a PyTorch model on Cloud ML Engine. The PyTorch model predicts whether the given sonar signals are bouncing off a metal cylinder or off a cylindrical rock from UCI Machine Learning Repository.
Citation: Dua, D. and Karra Taniskidou, E. (2017). UCI Machine Learning Repository [http://archive.ics.uci.edu/ml]. Irvine, CA: University of California, School of Information and Computer Science.
- Create your model
- Create the docker image
- Build the docker image
- Test your docker image locally
- Deploy the docker image to Cloud Container Registry
- Submit your training job
Before you jump in, let’s cover some of the different tools you’ll be using to get your container up and running on ML Engine.
Google Cloud Platform lets you build and host applications and websites, store data, and analyze data on Google's scalable infrastructure.
Cloud ML Engine is a managed service that enables you to easily build machine learning models that work on any type of data, of any size.
Cloud Container Registry is a single place for your team to manage Docker images, perform vulnerability analysis, and decide who can access what with fine-grained access control.
Google Cloud Storage (GCS) is a unified object storage for developers and enterprises, from live data serving to data analytics/ML to data archiving.
Cloud SDK is a command line tool which allows you to interact with Google Cloud products. In order to run this notebook, make sure that Cloud SDK is installed in the same environment as your Jupyter kernel.
docker is a containerization technology that allows developers to package their applications and dependencies easily so that they can be run anywhere.
- Create a project on GCP
- Create a Google Cloud Storage Bucket
- Enable Cloud Machine Learning Engine, Container Registry, and Compute Engine APIs
- Install Cloud SDK
- Install docker
- Configure docker for Cloud Container Registry
- Install PyTorch [Optional: used if running locally]
- Install pandas [Optional: used if running locally]
These variables will be needed for the following steps.
Replace these variables:
# PROJECT_ID: your project's id. Use the PROJECT_ID that matches your Google Cloud Platform project.
export PROJECT_ID=YOUR_PROJECT_ID
# BUCKET_ID: the bucket id you created above.
export BUCKET_ID=BUCKET_ID
Additional variables:
# IMAGE_REPO_NAME: the image will be stored on Cloud Container Registry
export IMAGE_REPO_NAME=sonar_pytorch_container
# IMAGE_TAG: an easily identifiable tag for your docker image
export IMAGE_TAG=sonar_pytorch
# IMAGE_URI: the complete URI location for Cloud Container Registry
export IMAGE_URI=gcr.io/$PROJECT_ID/$IMAGE_REPO_NAME:$IMAGE_TAG
# REGION: select a region from https://cloud.google.com/ml-engine/docs/regions
# or use the default '`us-central1`'. The region is where the model will be deployed.
export REGION=us-central1
# JOB_NAME: the name of your job running on Cloud ML Engine.
export JOB_NAME=custom_container_job_$(date +%Y%m%d_%H%M%S)
Here we provide an example model.py that trains a PyTorch model to predict whether the given sonar signals are bouncing off a metal cylinder or off a cylindrical rock.
Open up the task.py to see exactly how the model is called during training.
data_utils.py is used to download / load the data and exports your trained model and uploads the model to Google Cloud Storage.
The dataset for the model is hosted originally at the UCI Machine Learning Repository. We've hosted the sonar dataset in Cloud Storage for use with this sample.
Open the Dockerfile to see how the Docker image is created that will run on Cloud ML Engine.
docker build -f Dockerfile -t $IMAGE_URI ./
docker run $IMAGE_URI --epochs 1
If it runs successfully, the output should be similar to:
[1, 6] loss: 0.707
[1, 12] loss: 0.685
[1, 18] loss: 0.693
[1, 24] loss: 0.706
[1, 30] loss: 0.685
[1, 36] loss: 0.690
[1, 42] loss: 0.696
[1, 48] loss: 0.688
Test set:
Average loss: 2.8893
Accuracy: 121/208 (58%)
You should have configured docker to use Cloud Container Registry, found here.
docker push $IMAGE_URI
Submit the training job to Cloud ML Engine using gcloud
.
Note: You may need to install gcloud beta to submit the training job.
gcloud components install beta
gcloud beta ml-engine jobs submit training $JOB_NAME \
--region $REGION \
--master-image-uri $IMAGE_URI \
--scale-tier BASIC \
-- \
--model-dir=$BUCKET_ID \
--epochs=10
You can view the logs for your training job:
- Go to https://console.cloud.google.com/
- Select "Logging" in left-hand pane
- Select "Cloud ML Job" resource from the drop-down
- In filter by prefix, use the value of $JOB_NAME to view the logs
View the contents of the destination model folder to verify that model file has indeed been uploaded to GCS.
Note: The model can take a few minutes to train and show up in GCS.
gsutil ls gs://$BUCKET_ID/sonar_*