This repository is a fork of the original bigquery-long-running-jobs-metric-exporter repository.
This fork removes depracated call to empty providers and updates the google provider to version 5.0.
The iam section has been removed from the module and should be added manually to the project - as original one assumes quite big priviliges to be granted to the service account that manages TF resources (if projects are managed by different workflows and SA then it can be problematic).
If running with main project you need to add the following permissions to the service account that runs the workflow:
roles/bigquery.jobUser serviceAccount:[email protected]
roles/logging.logWriter serviceAccount:[email protected]
roles/monitoring.metricWriter serviceAccount:[email protected]
roles/workflows.invoker serviceAccount:long-running-jobs-wf-invoker@your-project.iam.gserviceaccount.com
Then for each monitored project you need to grant the following permissions:
roles/bigquery.resourceViewer serviceAccount:[email protected]
This repository contains a Google Cloud Workflow that monitors and exports a custom metric into Google Cloud Monitoring for "long running jobs". The definition of a long running job is configurable. A job is defined as long running if it is still running at the point the Workflow executes, and it has been running for longer than the defined threshold.
This Workflow can handle monitoring BigQuery jobs in multiple projects, and multiple regions, each of which can be easily configured.
Once deployed, this Workflow exports a custom GAUGE metric custom.googleapis.com/bigquery/long_running_jobs
labelled with the project ID and BigQuery region with the count of long running jobs.
You are then able to use the standard Google Cloud Monitoring tool set such as alerting, and dashboarding to monitor these jobs.
The Workflow is invoked by Cloud Scheduler, by default it will be invoked every 5 minutes (but this is configurable).
Cloud Scheduler invokes the Workflow with a payload containing information on the project ID's, and BigQuery regions to monitor for long running jobs, alongside some other configuration.
An example of the payload is shown below:
{
"config": {
"masterMetricProject": null,
"masterQueryProject": null,
"jobDurationAlertThreshold": "30"
},
"targets": {
"bigquery-project-1": [
"US",
"EU",
"europe-west2"
],
"bigquery-project-2": [
"europe-west2"
]
}
}
When the Workflow executes (triggered by Cloud Scheduler), it iterates through all of the keys (Project ID's) in .targets
.
For each Project ID, there is then a sub-iteration, which loops through each of the array items (BigQuery regions).
For each Project and BigQuery region, the Workflow executes the following query:
SELECT job_id FROM `<PROJECT_ID>`.`region-<REGION_ID>`.INFORMATION_SCHEMA.JOBS_BY_PROJECT WHERE state!=\"DONE\" AND creation_time >= TIMESTAMP_SUB(CURRENT_TIMESTAMP(), INTERVAL <CONFIGURED_INTERVAL> MINUTE)
The number of rows returned by this query is then written as a metric into Google Cloud Monitoring (custom.googleapis.com/bigquery/long_running_jobs
) labelled with the project id and the region.
By default, the Workflow runs the outstanding jobs query in the project that is being queried for outstanding jobs.
"targets": {
"bigquery-project-1": [
"US",
"EU",
"europe-west2"
],
"bigquery-project-2": [
"europe-west2"
]
}
For example, with the above configuration the query for outstanding jobs in bigquery-project-1
will be executed in bigquery-project-1
, and the query for outstanding jobs in bigquery-project-2
will be executed in bigquery-project-2
.
In some scenarios, it may be desired to execute the queries all from a single project. This can be easily configured by configuring the master_query_project
variable in module definition shown in the Deployment section. When this variable is set, all queries will be executed from the project defined in master_query_project
.
The same is true for metrics, by default, metrics are written to their respective projects.
In some scenarios, it may be desired to write metrics from multiple monitored projects to a single metrics project. This can be easily configured by configuring the master_metrics_project
variable in module definition shown in the Deployment section. When this variable is set, all metrics will be stored in the project defined in master_metrics_project
.
All queries, and metric writes are performed by a Service Account specifically created for the Cloud Workflow (long-running-jobs-workflow@<projectID>.iam.gserviceaccount.com
). Consequently, this Service Account needs some basic permissions:
roles/bigquery.resourceViewer
- Required in every project being monitored for long running jobs. This provides access to theINFORMATION_SCHEMA
tablesroles/bigquery.jobUser
- Required in every project being monitored, unlessmaster_query_project
is set (in which case it is only required there). This allows the Workflow to run queries.roles/monitoring.metricWriter
- Required in every project being monitored, unlessmaster_metrics_project
is set (in which case it is only required there). This allows the Workflow to write the outstanding jobs count to Google Cloud Monitoring.
Terraform handles all of these permissions automatically, including dynamically creating the required permissions depending on whether master_query_project
/master_metrics_project
is set.
All of the configuration and deployment of this Workflow is handled automatically using Terraform.
You can import the module in this repository into to an existing Terraform configuration, or define it in a standalone configuration.
The configuration variables are documented inline below:
module "long-running-jobs" {
source = "./terraform-module-long-running-jobs"
# These variables determine where the Workflow itself is deployed.
# A Service Account is also created in this project which is used
# for making the BigQuery Queries to determine long running jobs,
# and also to write metrics and logs from the Workflow run
workflow_deployment_project = "bigquery-job-alerting"
workflow_deployment_region = "europe-west2"
# map(list(string)) of projects and regions to monitor for long running jobs
# This variable defines the projects to be monitored, and which regions within
# that project to monitor
monitored_projects_and_regions = {
"bigquery-job-alerting" = ["US", "EU", "europe-west2"],
}
# The duration queries should be running for before the alert is triggered
job_duration_alert_threshold_minutes = 30
# By default, queries for long running jobs are performed in the project that is being
# queried. For example if two projects "project-a" and "project-b" are being monitored,
# the query for "project-a" is run in "project-a", and the query for "project-b" is run
# in "project-b".
#
# In some scenarios - it may be desirable to run all of the queries from a single project.
# In order to do this, set the master_query_project below to a valid project ID
master_query_project = ""
# By default, metrics for long running jobs are stored in the project that is being
# queried. For example if two projects "project-a" and "project-b" are being monitored,
# the long running jobs metric for "project-a" is stored in "project-a", and the long
# running jobs metric for "project-b" is stored in "project-b".
#
# In some scenarios - it may be desirable to aggregate all metrics in a single project
# In order to do this, set the master_metrics_project below to a valid project ID
master_metrics_project = ""
# How often should a query be made for Long Running Jobs? This should be in Crontab format and
# defaults to every 5 minutes
long_running_job_polling_period = "*/5 * * * *"
}