# Google Cloud Platform ## Introduction This project allows you to get hold of some machine on Google Cloud Platform. You can then use these machines as is or run various Ansible playbooks from `../config_management` to set up Weave Net, Kubernetes, etc. ## Setup * Log in [console.cloud.google.com](https://console.cloud.google.com) with your Google account. * Go to `API Manager` > `Credentials` > `Create credentials` > `Service account key`, in `Service account`, select `Compute Engine default service account`, in `Key type`, select `JSON`, and then click `Create`. * This will download a JSON file to your machine. Place this file wherever you want and then create the following environment variables: ``` $ export GOOGLE_CREDENTIALS_FILE="path/to/your.json" $ export GOOGLE_CREDENTIALS=$(cat "$GOOGLE_CREDENTIALS_FILE") ``` * Go to `Compute Engine` > `Metadata` > `SSH keys` and add your username and SSH public key; or set it up using `gcloud compute project-info add-metadata --metadata-from-file sshKeys=~/.ssh/id_rsa.pub`. If you used your default SSH key (i.e. `~/.ssh/id_rsa.pub`), then you do not have anything to do. Otherwise, you will have to either define the below environment variable: ``` $ export TF_VAR_gcp_public_key_path= $ export TF_VAR_gcp_private_key_path= ``` or to pass these as Terraform variables: ``` $ terraform \ -var 'gcp_public_key_path=' \ -var 'gcp_private_key_path=' ``` * Set the username in your public key as an environment variable. This will be used as the username of the Linux account created on the machine, which you will need to SSH into it later on. N.B.: * GCP already has the username set from the SSH public key you uploaded in the previous step. * If your username is an email address, e.g. `name@domain.com`, then GCP uses `name` as the username. ``` export TF_VAR_gcp_username= ``` * Set your current IP address as an environment variable: ``` export TF_VAR_client_ip=$(curl -s -X GET http://checkip.amazonaws.com/) ``` or pass it as a Terraform variable: ``` $ terraform -var 'client_ip=$(curl -s -X GET http://checkip.amazonaws.com/)' ``` * Set your project as an environment variable: ``` export TF_VAR_gcp_project=weave-net-tests ``` or pass it as a Terraform variable: ``` $ terraform -var 'gcp_project=weave-net-tests' ``` ### Bash aliases You can set the above variables temporarily in your current shell, permanently in your `~/.bashrc` file, or define aliases to activate/deactivate them at will with one single command by adding the below to your `~/.bashrc` file: ``` function _gcp_on() { export GOOGLE_CREDENTIALS_FILE="