This repo will help you to deploy your a google compute engine VM Instance to Google cloud platform using terraform, Also I used one python script for transfering csv data to my cloud storage bucket to a bigquery dataset table.
This repo contains several terraform configuration files & a python script file.
This terraform file is used to configure google compute engine vm instance, their machine type, image, network configuration, start up script, metadata etc. you can change it according to your requirement.
Basically, this is a file which defines provider and terraform version you used to deploy your infrastructure. I suggest go with latest one but here in this repo I used older one which is terraform 0.12. If you're using cloud shell than this version is already installed in your machine.
This script file is used to transfer csv data from existing google cloud storage to bigquery dataset table. I used some google storage & bigquery client library in this file.
- a GCP account
- python 3.6 or greater (Latest one is recommanded)
- a configured gcloud SDK
- storage client library for python
- bigquery client library for python
- terraform
-
create a service account with proper permissions like here our script is working with cloud storage & bigquery so give permission accordingly & generate a json api key to use it in futher step.
-
clone the repo into your machine
- Change the directory where all files are located
- $cd cloud_storage_to_bigQuery
- see the all configuration files & if required change it accordingly.
Note: Change environment variable GOOGLE CLOUD CREDENTIAL path with your downloaded json key path.
- Now, initiaze the terraform in this folder & check all things are working well, Also review deployments.
-
$terraform init
-
$terraform plan
- If you don't get any error then let's deploy our configuration
- $terraform apply
- now ssh to your vm instance
- $gcloud compute ssh --project=PROJECT_ID --zone=ZONE VM_NAME
- try to run script.py using python3
- $python3 script.py
you'll see output as some insertions are taken place, got to your bigquery table and verify your cloud storage data has been added.
- After experimenting with this demo, let's clean up & destroy what we deployed
- $terraform destroy