This tutorial shows how to export a BigQuery ML model
and then deploy the model either on Vertex AI or on a local machine. You will
use the iris table
from the BigQuery public datasets and work through the following three end-to-end scenarios:
- Train and deploy a logistic regression model - also applies to DNN classifier, DNN regressor, k-means, linear regression, and matrix factorization models.
- Train and deploy a boosted tree classifier model - also applies to boosted tree regressor model.
- Train and deploy an AutoML classifier model - also applies to AutoML regressor model.
Costs
This tutorial uses billable components of Google Cloud, including:
- BigQuery ML
- Cloud Storage
- Vertex AI (optional, used for online prediction)
For more information about BigQuery ML costs, see BigQuery ML pricing.
For more information about Cloud Storage costs, see the Cloud Storage pricing page.
For more information about Vertex AI costs, see Custom-trained models.
Before you begin
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
    
    
      In the Google Cloud console, on the project selector page, select or create a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- BigQuery is automatically enabled in new projects.
  To activate BigQuery in a pre-existing project, go to
  
  
  
  
  
    
    
      
    
  
  
  
  
    
      Enable the BigQuery API. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- 
  
  
  
    
    
  
  
  
  
    
      Enable the AI Platform Training and Prediction API and Compute Engine APIs. Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
- Install the Google Cloud CLI and the Google Cloud CLI.
Create your dataset
Create a BigQuery dataset to store your ML model.
Console
- In the Google Cloud console, go to the BigQuery page. 
- In the Explorer pane, click your project name. 
- Click View actions > Create dataset 
- On the Create dataset page, do the following: - For Dataset ID, enter - bqml_tutorial.
- For Location type, select Multi-region, and then select US (multiple regions in United States). 
- Leave the remaining default settings as they are, and click Create dataset. 
 
bq
To create a new dataset, use the
bq mk command
with the --location flag. For a full list of possible parameters, see the
bq mk --dataset command
reference.
- Create a dataset named - bqml_tutorialwith the data location set to- USand a description of- BigQuery ML tutorial dataset:- bq --location=US mk -d \ --description "BigQuery ML tutorial dataset." \ bqml_tutorial - Instead of using the - --datasetflag, the command uses the- -dshortcut. If you omit- -dand- --dataset, the command defaults to creating a dataset.
- Confirm that the dataset was created: - bq ls
API
Call the datasets.insert
method with a defined dataset resource.
{ "datasetReference": { "datasetId": "bqml_tutorial" } }
BigQuery DataFrames
Before trying this sample, follow the BigQuery DataFrames setup instructions in the BigQuery quickstart using BigQuery DataFrames. For more information, see the BigQuery DataFrames reference documentation.
To authenticate to BigQuery, set up Application Default Credentials. For more information, see Set up ADC for a local development environment.
Train and deploy a logistic regression model
Use the following sections to learn how to train and deploy a logistic regression model.
Train the model
Train a logistic regression model that predicts iris type using the
BigQuery ML CREATE MODEL
statement. This training job should take approximately 1 minute to complete.
bq query --use_legacy_sql=false \ 'CREATE MODEL `bqml_tutorial.iris_model` OPTIONS (model_type="logistic_reg", max_iterations=10, input_label_cols=["species"]) AS SELECT * FROM `bigquery-public-data.ml_datasets.iris`;'
Export the model
Export the model to a Cloud Storage bucket using the bq command-line tool. For additional ways to export models, see Export BigQuery ML models. This extract job should take less than 1 minute to complete.
bq extract -m bqml_tutorial.iris_model gs://some/gcs/path/iris_model
Local deployment and serving
You can deploy exported TensorFlow models using the TensorFlow Serving Docker container. The following steps require you to install Docker.
Download the exported model files to a temporary directory
mkdir tmp_dir
gcloud storage cp gs://some/gcs/path/iris_model tmp_dir --recursive
Create a version subdirectory
This step sets a version number (1 in this case) for the model.
mkdir -p serving_dir/iris_model/1
cp -r tmp_dir/iris_model/* serving_dir/iris_model/1
rm -r tmp_dir
Pull the Docker image
docker pull tensorflow/serving
Run the Docker container
docker run -p 8500:8500 --network="host" --mount type=bind,source=`pwd`/serving_dir/iris_model,target=/models/iris_model -e MODEL_NAME=iris_model -t tensorflow/serving &
Run the prediction
curl -d '{"instances": [{"sepal_length":5.0, "sepal_width":2.0, "petal_length":3.5, "petal_width":1.0}]}' -X POST http://localhost:8501/v1/models/iris_model:predict
Online deployment and serving
This section uses the Google Cloud CLI to deploy and run predictions against the exported model.
For more information about deploying a model to Vertex AI for online or batch predictions, see Deploy a model to an endpoint.
Create a model resource
MODEL_NAME="IRIS_MODEL"
gcloud ai-platform models create $MODEL_NAME
Create a model version
1) Set the environment variables:
MODEL_DIR="gs://some/gcs/path/iris_model"
// Select a suitable version for this model
VERSION_NAME="v1"
FRAMEWORK="TENSORFLOW"
2) Create the version:
gcloud ai-platform versions create $VERSION_NAME --model=$MODEL_NAME --origin=$MODEL_DIR --runtime-version=1.15 --framework=$FRAMEWORK
This step might take a few minutes to complete. You should see the message
Creating version (this might take a few minutes).......
3) (optional) Get information about your new version:
gcloud ai-platform versions describe $VERSION_NAME --model $MODEL_NAME
You should see output similar to this:
createTime: '2020-02-28T16:30:45Z'
deploymentUri: gs://your_bucket_name
framework: TENSORFLOW
machineType: mls1-c1-m2
name: projects/[YOUR-PROJECT-ID]/models/IRIS_MODEL/versions/v1
pythonVersion: '2.7'
runtimeVersion: '1.15'
state: READY
Online prediction
For more information about about running online predictions against a deployed model, see Get online inferences from a custom trained model.
1) Create a newline-delimited JSON file for inputs, for example instances.json
file with the following content:
{"sepal_length":5.0, "sepal_width":2.0, "petal_length":3.5, "petal_width":1.0}
{"sepal_length":5.3, "sepal_width":3.7, "petal_length":1.5, "petal_width":0.2}
2) Setup env variables for predict:
INPUT_DATA_FILE="instances.json"
3) Run predict:
gcloud ai-platform predict --model $MODEL_NAME --version $VERSION_NAME --json-instances $INPUT_DATA_FILE
Train and deploy a boosted tree classifier model
Use the following sections to learn how to train and deploy a boosted tree classifier model.
Train the model
Train a boosted tree classifier model that predicts iris type using the
CREATE MODEL
statement. This training job should take approximately 7 minutes to complete.
bq query --use_legacy_sql=false \ 'CREATE MODEL `bqml_tutorial.boosted_tree_iris_model` OPTIONS (model_type="boosted_tree_classifier", max_iterations=10, input_label_cols=["species"]) AS SELECT * FROM `bigquery-public-data.ml_datasets.iris`;'
Export the model
Export the model to a Cloud Storage bucket using the bq command-line tool. For additional ways to export models, see Export BigQuery ML models.
bq extract --destination_format ML_XGBOOST_BOOSTER -m bqml_tutorial.boosted_tree_iris_model gs://some/gcs/path/boosted_tree_iris_model
Local deployment and serving
In the exported files, there is a main.py file for local run.
Download the exported model files to a local directory
mkdir serving_dir
gcloud storage cp gs://some/gcs/path/boosted_tree_iris_model serving_dir --recursive
Extract predictor
tar -xvf serving_dir/boosted_tree_iris_model/xgboost_predictor-0.1.tar.gz -C serving_dir/boosted_tree_iris_model/
Install XGBoost library
Install the XGBoost library - version 0.82 or later.
Run the prediction
cd serving_dir/boosted_tree_iris_model/
python main.py '[{"sepal_length":5.0, "sepal_width":2.0, "petal_length":3.5, "petal_width":1.0}]'
Online deployment and serving
This section uses the Google Cloud CLI to deploy and run predictions against the exported model. For more information, see Get online inferences from a custom trained model.
For more information about deploying a model to Vertex AI for online or batch predictions using custom routines, see Deploy a model to an endpoint.
Create a model resource
MODEL_NAME="BOOSTED_TREE_IRIS_MODEL"
gcloud ai-platform models create $MODEL_NAME
Create a model version
1) Set the environment variables:
MODEL_DIR="gs://some/gcs/path/boosted_tree_iris_model"
VERSION_NAME="v1"
2) Create the version:
gcloud beta ai-platform versions create $VERSION_NAME --model=$MODEL_NAME --origin=$MODEL_DIR --package-uris=${MODEL_DIR}/xgboost_predictor-0.1.tar.gz --prediction-class=predictor.Predictor --runtime-version=1.15
This step might take a few minutes to complete. You should see the message
Creating version (this might take a few minutes).......
3) (optional) Get information about your new version:
gcloud ai-platform versions describe $VERSION_NAME --model $MODEL_NAME
You should see output similar to this:
createTime: '2020-02-07T00:35:42Z'
deploymentUri: gs://some/gcs/path/boosted_tree_iris_model
etag: rp090ebEnQk=
machineType: mls1-c1-m2
name: projects/[YOUR-PROJECT-ID]/models/BOOSTED_TREE_IRIS_MODEL/versions/v1
packageUris:
- gs://some/gcs/path/boosted_tree_iris_model/xgboost_predictor-0.1.tar.gz
predictionClass: predictor.Predictor
pythonVersion: '2.7'
runtimeVersion: '1.15'
state: READY
Online prediction
For more information about running online predictions against a deployed model, see Get online inferences from a custom trained model.
1) Create a newline-delimited JSON file for inputs. For example, instances.json
file with the following content:
{"sepal_length":5.0, "sepal_width":2.0, "petal_length":3.5, "petal_width":1.0}
{"sepal_length":5.3, "sepal_width":3.7, "petal_length":1.5, "petal_width":0.2}
2) Set up environment variables for predict:
INPUT_DATA_FILE="instances.json"
3) Run predict:
gcloud ai-platform predict --model $MODEL_NAME --version $VERSION_NAME --json-instances $INPUT_DATA_FILE
Train and deploy an AutoML classifier model
Use the following sections to learn how to train and deploy an AutoML classifier model.
Train the model
Train an AutoML classifier model that predicts iris type using the
CREATE MODEL
statement. AutoML models need at least 1000 rows of input data. Because
ml_datasets.iris only has 150 rows, we duplicate the data 10 times. This
training job should take around 2 hours to complete.
bq query --use_legacy_sql=false \ 'CREATE MODEL `bqml_tutorial.automl_iris_model` OPTIONS (model_type="automl_classifier", budget_hours=1, input_label_cols=["species"]) AS SELECT * EXCEPT(multiplier) FROM `bigquery-public-data.ml_datasets.iris`, unnest(GENERATE_ARRAY(1, 10)) as multiplier;'
Export the model
Export the model to a Cloud Storage bucket using the bq command-line tool. For additional ways to export models, see Exporting BigQuery ML models.
bq extract -m bqml_tutorial.automl_iris_model gs://some/gcs/path/automl_iris_model
Local deployment and serving
For details about building AutoML containers, see Exporting models. The following steps require you to install Docker.
Copy exported model files to a local directory
mkdir automl_serving_dir
gcloud storage cp gs://some/gcs/path/automl_iris_model/* automl_serving_dir/ --recursive
Pull AutoML Docker image
docker pull gcr.io/cloud-automl-tables-public/model_server
Start Docker container
docker run -v `pwd`/automl_serving_dir:/models/default/0000001 -p 8080:8080 -it gcr.io/cloud-automl-tables-public/model_server
Run the prediction
1) Create a newline-delimited JSON file for inputs. For example, input.json
file with the following contents:
{"instances": [{"sepal_length":5.0, "sepal_width":2.0, "petal_length":3.5, "petal_width":1.0},
{"sepal_length":5.3, "sepal_width":3.7, "petal_length":1.5, "petal_width":0.2}]}
2) Make the predict call:
curl -X POST --data @input.json http://localhost:8080/predict
Online deployment and serving
Online prediction for AutoML regressor and AutoML classifier models is not supported in Vertex AI.
Clean up
To avoid incurring charges to your Google Cloud account for the resources used in this tutorial, either delete the project that contains the resources, or keep the project and delete the individual resources.
- You can delete the project you created.
- Or you can keep the project and delete the dataset and Cloud Storage bucket.
Stop Docker container
1) List all running Docker containers.
docker ps
2) Stop the container with the applicable container ID from the container list.
docker stop container_id
Delete Vertex AI resources
1) Delete the model version.
gcloud ai-platform versions delete $VERSION_NAME --model=$MODEL_NAME
2) Delete the model.
gcloud ai-platform models delete $MODEL_NAME
Delete your dataset
Deleting your project removes all datasets and all tables in the project. If you prefer to reuse the project, you can delete the dataset you created in this tutorial:
- If necessary, open the BigQuery page in the Google Cloud console. 
- In the navigation, click the bqml_tutorial dataset you created. 
- Click Delete dataset on the right side of the window. This action deletes the dataset, the table, and all the data. 
- In the Delete dataset dialog, confirm the delete command by typing the name of your dataset ( - bqml_tutorial) and then click Delete.
Delete your Cloud Storage bucket
Deleting your project removes all Cloud Storage buckets in the project. If you prefer to reuse the project, you can delete the bucket you created in this tutorial
- In the Google Cloud console, go to the Cloud Storage Buckets page.
 
- Select the checkbox of the bucket you want to delete. 
- Click Delete. 
- In the overlay window that appears, confirm you want to delete the bucket and its contents by clicking Delete. 
Delete your project
To delete the project:
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
What's next
- For an overview of BigQuery ML, see Introduction to BigQuery ML.
- For information on exporting models, see Export models.
- For information on creating models, see the
CREATE MODELsyntax page.