# Google Cloud BigQuery

The *Google Cloud BigQuery* output plugin is an experimental plugin that lets you stream records into the [Google Cloud BigQuery](https://cloud.google.com/bigquery/) service.

The implementation doesn't support the following, which would be expected in a full production version:

* [Application Default Credentials](https://cloud.google.com/docs/authentication/production).
* [Data deduplication](https://cloud.google.com/bigquery/streaming-data-into-bigquery) using `insertId`.
* [Template tables](https://cloud.google.com/bigquery/streaming-data-into-bigquery) using `templateSuffix`.

## Google Cloud configuration

Fluent Bit streams data into an existing BigQuery table using a service account that you specify. Before using the BigQuery output plugin, you must:

1. To stream data into BigQuery, you must create a [Google Cloud service account](https://cloud.google.com/iam/docs/creating-managing-service-accounts) for Fluent Bit.
2. Create a BigQuery dataset. Fluent Bit doesn't create datasets for your data, so you must [create the dataset](https://cloud.google.com/bigquery/docs/datasets) ahead of time. You must also grant the service account `WRITER` permission on the dataset.

   Within the dataset you must create a table for the data to reside in. Use the following instructions for creating your table. Pay close attention to the schema, as it must match the schema of your output JSON. Unfortunately, because BigQuery doesn't allow dots in field names, you must use a filter to change the fields for many of the standard inputs (for example, `mem` or `cpu`).
3. [Create a BigQuery table](https://cloud.google.com/bigquery/docs/tables).
4. Fluent Bit BigQuery output plugin uses a JSON credentials file for authentication credentials. [Authorize the service account](https://cloud.google.com/iam/docs/creating-managing-service-account-keys) to write to the table.
5. Provide the service account credentials to Fluent Bit. With [workload identity federation](https://cloud.google.com/iam/docs/workload-identity-federation), you can grant on-premises or multi-cloud workloads access to Google Cloud resources, without using a service account key. It can be used as a more secure alternative to service account credentials. Google Cloud's workload identity federation supports several identity providers (see documentation) but Fluent Bit BigQuery plugin currently supports Amazon Web Services (AWS) only.

   You must configure workload identity federation in GCP before using it with Fluent Bit.

   * [Configuring workload identity federation](https://cloud.google.com/iam/docs/configuring-workload-identity-federation#aws)
   * [Obtaining short-lived credentials with identity federation](https://cloud.google.com/iam/docs/using-workload-identity-federation)

## Configurations parameters

| Key                                   | Description                                                                                                                                                                                                                                                             | Default                                                          |
| ------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------- |
| `google_service_credentials`          | Absolute path to a Google Cloud credentials JSON file.                                                                                                                                                                                                                  | Value of the environment variable `$GOOGLE_SERVICE_CREDENTIALS`. |
| `project_id`                          | The project id containing the BigQuery dataset to stream into.                                                                                                                                                                                                          | Value of the `project_id` in the credentials file.               |
| `dataset_id`                          | The dataset id of the BigQuery dataset to write into. This dataset must exist in your project.                                                                                                                                                                          | *none*                                                           |
| `table_id`                            | The table id of the BigQuery table to write into. This table must exist in the specified dataset and the schema must match the output.                                                                                                                                  | *none*                                                           |
| `skip_invalid_rows`                   | Insert all valid rows of a request, even if invalid rows exist. The default value is false, which causes the entire request to fail if any invalid rows exist.                                                                                                          | `Off`                                                            |
| `ignore_unknown_values`               | Accept rows that contain values that don't match the schema. The unknown values are ignored. Default is `Off`, which treats unknown values as errors.                                                                                                                   | `Off`                                                            |
| `enable_workload_identity_federation` | Enables workload identity federation as an alternative authentication method. Can't be used with service account credentials file or environment variable. AWS is the only identity provider currently supported.                                                       | `Off`                                                            |
| `aws_region`                          | Used to construct a regional endpoint for AWS STS to verify AWS credentials obtained by Fluent Bit. Regional endpoints are recommended by AWS.                                                                                                                          | *none*                                                           |
| `project_number`                      | GCP project number where the identity provider was created. Used to construct the full resource name of the identity provider.                                                                                                                                          | *none*                                                           |
| `pool_id`                             | GCP workload identity pool where the identity provider was created. Used to construct the full resource name of the identity provider.                                                                                                                                  | *none*                                                           |
| `provider_id`                         | GCP workload identity provider. Used to construct the full resource name of the identity provider. Currently only AWS accounts are supported.                                                                                                                           | *none*                                                           |
| `google_service_account`              | The email address of the Google service account to impersonate. The workload identity provider must have permissions to impersonate this service account, and the service account must have permissions to access Google BigQuery resources ( `write` access to tables) | *none*                                                           |
| `workers`                             | The number of [workers](https://docs.fluentbit.io/manual/4.1/administration/multithreading#outputs) to perform flush operations for this output.                                                                                                                        | `0`                                                              |

See Google's [official documentation](https://cloud.google.com/bigquery/docs/reference/rest/v2/tabledata/insertAll) for further details.

## Configuration file

If you are using a Google Cloud credentials file, the following configuration will get you started:

{% tabs %}
{% tab title="fluent-bit.yaml" %}

```yaml
pipeline:
  inputs:
    - name: dummy
      tag: dummy

  outputs:
    - name: bigquery
      match: '*'
      dataset_id: my_dataset
      table_id: dummy_table
```

{% endtab %}

{% tab title="fluent-bit.conf" %}

```
[INPUT]
  Name dummy
  Tag  dummy

[OUTPUT]
  Name         bigquery
  Match        *
  dataset_id   my_dataset
  table_id     dummy_table
```

{% endtab %}
{% endtabs %}
