This repository contains two Looker blocks for analysing Google Cloud Platform logs. We provide a Looker model called GCP Billing which sits on top of GCP billing log exports. This model allows you to analyse billing data across projects and across services and resource types, allowing you to efficiently manage you GCP Billing account. We also provide projected monthly spend based on your current daily billing, so you can take actions to control spending across your organisation.
We also provide a model to anlayse BigQuery data access logs. The model sits on top of a Stackdriver Logging export of BigQuery queries and data access. This allows you to effectively monitor BigQuery performance and cost at a per user level. It can be used to set up alerts to long running or high cost queries. Below we also detail a method to analyse these logs across several projects, allowing you to visualise your BigQuery organisation in one place.
Let's run through the steps in both the Google Cloud Platform, and in Looker, to setup the logging exports and the Looker block.
Create a BigQuery dataset for the billing and BigQuery audit logs. Go to the Google Cloud Platform console, and select BigQuery, or go to https://bigquery.cloud.google.com/. Click the drop down next to the project name and select Create New Dataset, set a location and click OK.
Optional: We recommend setting up a new GCP Project, purely for this purpose.
To setup a billing export to BigQuery do the following:
- Go to the Google Cloud Platform console and select Billing
- Choose the appropriate billing account (if you have more than one) using Manage billing accounts
- Click Billing Export > BigQuery export
- Select the Project and Dataset you created earlier
- Click Enable BigQuery export
Billing data will now be exported to your dataset at regular intervals. The Billing export table is date partitioned, and will incur a small data storage charge.
To set up the BigQuery log export do the following in a project that contains BigQuery:
- First, you need to add an empty dataset on BigQuery where the log will be exported. Go to the Google Cloud Platform console and select BigQuery
- Select your project and click on Create Dataset. Enter a name under "Dataset ID" (e.g.
gcp_logs
) and click on Create Dataset - You will now configure the BigQuery log to be explorted into that dataset. Go to the Google Cloud Platform console and select Logging (in the Operations suite)
- Click on Logs Router and then on Create Sink
- Click on the arrow on the right of the search box, and then on "Convert to advanced filter"
- In the new text box, type
resource.type = bigquery_resource OR resource.type = bigquery_project OR resource.type = bigquery_dataset
- Under "Edit Sink":
a. Under "Edit Name", enter a name (e.g.
bigquery-sink-v1
) b. Under "Sink Service", select BigQuery Sink and click the Use Partitioned Tables tickbox c. Under "Sink Destination", select the BigQuery Dataset that you created in step 2 d. Click on Create sink
If you got a permission error then that is perfectly normal. It is because the project you have set up the export to is different to the project you have set up the logging export in. In this case the Service Account which writes the logs into the BigQuery dataset you have created will not have permission to do so. Follow the steps below to complete the setup:
- Go to BigQuery in the project the logs are exported to and click on the dropdown next to the dataset you have chosen. Click Share Dataset
- Get the name of the service account by going to Logs Router under Logging in the project where you set up the logging export, and copy the Writer Identity
- Add this Writer Identity into the Share Dataset window in BigQuery from Step 1
- Give the account Can edit access, and click Add, and then Save Changes
The BigQuery audit log export should now be set up. The table will be updated throughout the day. The BigQuery audit log table is partitioned rather than date sharded.
If you have more than one project using BigQuery, repeat the steps above. All logs from different projects will be added to the same table, allowing easy querying across projects.
The BigQuery Audit Logs export pulls in both the AuditData and BigQueryAuditMetadata logs. AuditData is the older version of the logs, and BigQueryAuditMetadata is the new which ADDS new columns. These are therefore unioned in the table. The lookml model pulls from the older version, but you have the ability to model the new columns into the model should you wish. You should only use ROW COUNT with Method Name filter applied.
Alternatively, if you have the Google Cloud SDK installed, you can set up the BigQuery logging using the following command (make sure you in the project you want to set up the logging for by running gcloud config set project <project-name>
)
gcloud beta logging sinks create <sink_name> bigquery.googleapis.com/projects/<project-name>/datasets/<dataset-name> --log-filter='resource.type="bigquery_resource OR resource.type = bigquery_project OR resource.type = bigquery_dataset"'
This block requires almost no configuration once added to your Looker instance. We will only need to change the billing export table name:
- Go to BigQuery and copy the name of the billing export table, this will start gcp_billing_export_
- In Looker, go to the view file gcp_billing_export
- Replace the table name in the FROM statement of the derived table with your billing export table name
- Create a new Database Connection in Looker to connect to the BigQuery dataset: follow the steps here to create a service account in GCP and add a new connection to Looker, ensure you use BigQuery standard SQL
- Change the connection name in the Looker model files to the connection name you chose in Step 4
You should now be ready to start monitoring your BigQuery and GCP usage.