BigQueryDataTransferConfig
Property | Value |
---|---|
Google Cloud Service Name | BigQuery Data Transfer |
Google Cloud Service Documentation | /bigquery/docs/ |
Google Cloud REST Resource Name | v1beta1.projects.locations.transferConfigs |
Google Cloud REST Resource Documentation | /bigquery/docs/reference/datatransfer/rest/v1/projects.locations.transferConfigs |
Config Connector Resource Short Names | bigquerydatatransferconfig |
Config Connector Service Name | bigquerydatatransfer.googleapis.com |
Config Connector Resource Fully Qualified Name | bigquerydatatransferconfigs.bigquerydatatransfer.cnrm.cloud.google.com |
Can Be Referenced by IAMPolicy/IAMPolicyMember | No |
Config Connector Default Average Reconcile Interval In Seconds | 600 |
Custom Resource Definition Properties
Spec
Schema
dataRefreshWindowDays: integer
dataSourceID: string
datasetRef:
external: string
name: string
namespace: string
disabled: boolean
displayName: string
emailPreferences:
enableFailureEmail: boolean
encryptionConfiguration:
kmsKeyRef:
external: string
name: string
namespace: string
location: string
params:
string: string
projectRef:
external: string
kind: string
name: string
namespace: string
pubSubTopicRef:
external: string
name: string
namespace: string
resourceID: string
schedule: string
scheduleOptions:
disableAutoScheduling: boolean
endTime: string
startTime: string
serviceAccountRef:
external: string
name: string
namespace: string
Fields | |
---|---|
Optional |
The number of days to look back to automatically refresh the data. For example, if `data_refresh_window_days = 10`, then every day BigQuery reingests data for [today-10, today-1], rather than ingesting data for just [today-1]. Only valid if the data source supports the feature. Set the value to 0 to use the default value. |
Required |
Immutable. Data source ID. This cannot be changed once data transfer is created. The full list of available data source IDs can be returned through an API call: https://cloud.google.com/bigquery-transfer/docs/reference/datatransfer/rest/v1/projects.locations.dataSources/list |
Required |
The BigQuery target dataset id. |
Optional |
If provided must be in the format `projects/[project_id]/datasets/[dataset_id]`. |
Optional |
The `metadata.name` field of a `BigQueryDataset` resource. |
Optional |
The `metadata.namespace` field of a `BigQueryDataset` resource. |
Optional |
Is this config disabled. When set to true, no runs will be scheduled for this transfer config. |
Optional |
User specified display name for the data transfer. |
Optional |
Email notifications will be sent according to these preferences to the email address of the user who owns this transfer config. |
Optional |
If true, email notifications will be sent on transfer run failures. |
Optional |
The encryption configuration part. Currently, it is only used for the optional KMS key name. The BigQuery service account of your project must be granted permissions to use the key. Read methods will return the key name applied in effect. Write methods will apply the key if it is present, or otherwise try to apply project default keys if it is absent. |
Optional |
The KMS key used for encrypting BigQuery data. |
Optional |
A reference to an externally managed KMSCryptoKey. Should be in the format `projects/[kms_project_id]/locations/[region]/keyRings/[key_ring_id]/cryptoKeys/[key]`. |
Optional |
The `name` of a `KMSCryptoKey` resource. |
Optional |
The `namespace` of a `KMSCryptoKey` resource. |
Required |
Immutable. |
Required |
Parameters specific to each data source. For more information see the bq tab in the 'Setting up a data transfer' section for each data source. For example the parameters for Cloud Storage transfers are listed here: https://cloud.google.com/bigquery-transfer/docs/cloud-storage-transfer#bq |
Required |
The Project that this resource belongs to. |
Optional |
The `projectID` field of a project, when not managed by Config Connector. |
Optional |
The kind of the Project resource; optional but must be `Project` if provided. |
Optional |
The `name` field of a `Project` resource. |
Optional |
The `namespace` field of a `Project` resource. |
Optional |
Pub/Sub topic where notifications will be sent after transfer runs associated with this transfer config finish. |
Optional |
If provided must be in the format `projects/[project_id]/topics/[topic_id]`. |
Optional |
The `metadata.name` field of a `PubSubTopic` resource. |
Optional |
The `metadata.namespace` field of a `PubSubTopic` resource. |
Optional |
Immutable. The BigQueryDataTransferConfig name. If not given, the metadata.name will be used. |
Optional |
Data transfer schedule. If the data source does not support a custom schedule, this should be empty. If it is empty, the default value for the data source will be used. The specified times are in UTC. Examples of valid format: `1st,3rd monday of month 15:30`, `every wed,fri of jan,jun 13:15`, and `first sunday of quarter 00:00`. See more explanation about the format here: https://cloud.google.com/appengine/docs/flexible/python/scheduling-jobs-with-cron-yaml#the_schedule_format NOTE: The minimum interval time between recurring transfers depends on the data source; refer to the documentation for your data source. |
Optional |
Options customizing the data transfer schedule. |
Optional |
If true, automatic scheduling of data transfer runs for this configuration will be disabled. The runs can be started on ad-hoc basis using StartManualTransferRuns API. When automatic scheduling is disabled, the TransferConfig.schedule field will be ignored. |
Optional |
Defines time to stop scheduling transfer runs. A transfer run cannot be scheduled at or after the end time. The end time can be changed at any moment. The time when a data transfer can be triggered manually is not limited by this option. |
Optional |
Specifies time to start scheduling transfer runs. The first run will be scheduled at or after the start time according to a recurrence pattern defined in the schedule string. The start time can be changed at any moment. The time when a data transfer can be triggered manually is not limited by this option. |
Optional |
Service account email. If this field is set, the transfer config will be created with this service account's credentials. It requires that the requesting user calling this API has permissions to act as this service account. Note that not all data sources support service account credentials when creating a transfer config. For the latest list of data sources, please refer to https://cloud.google.com/bigquery/docs/use-service-accounts. |
Optional |
The `email` field of an `IAMServiceAccount` resource. |
Optional |
Name of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names |
Optional |
Namespace of the referent. More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ |
Status
Schema
conditions:
- lastTransitionTime: string
message: string
reason: string
status: string
type: string
externalRef: string
observedGeneration: integer
observedState:
datasetRegion: string
name: string
nextRunTime: string
ownerInfo:
email: string
state: string
updateTime: string
userID: integer
Fields | |
---|---|
conditions |
Conditions represent the latest available observations of the object's current state. |
conditions[] |
|
conditions[].lastTransitionTime |
Last time the condition transitioned from one status to another. |
conditions[].message |
Human-readable message indicating details about last transition. |
conditions[].reason |
Unique, one-word, CamelCase reason for the condition's last transition. |
conditions[].status |
Status is the status of the condition. Can be True, False, Unknown. |
conditions[].type |
Type is the type of the condition. |
externalRef |
A unique specifier for the BigQueryDataTransferConfig resource in GCP. |
observedGeneration |
ObservedGeneration is the generation of the resource that was most recently observed by the Config Connector controller. If this is equal to metadata.generation, then that means that the current reported status reflects the most recent desired state of the resource. |
observedState |
ObservedState is the state of the resource as most recently observed in GCP. |
observedState.datasetRegion |
Output only. Region in which BigQuery dataset is located. |
observedState.name |
Identifier. The resource name of the transfer config. Transfer config names have the form either `projects/{project_id}/locations/{region}/transferConfigs/{config_id}` or `projects/{project_id}/transferConfigs/{config_id}`, where `config_id` is usually a UUID, even though it is not guaranteed or required. The name is ignored when creating a transfer config. |
observedState.nextRunTime |
Output only. Next time when data transfer will run. |
observedState.ownerInfo |
Output only. Information about the user whose credentials are used to transfer data. Populated only for `transferConfigs.get` requests. In case the user information is not available, this field will not be populated. |
observedState.ownerInfo.email |
E-mail address of the user. |
observedState.state |
Output only. State of the most recently updated transfer run. |
observedState.updateTime |
Output only. Data transfer modification time. Ignored by server on input. |
observedState.userID |
Deprecated. Unique ID of the user on whose behalf transfer is done. |
Sample YAML(s)
BigQueryDataTransferConfig Scheduledquery
# Copyright 2024 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
apiVersion: bigquerydatatransfer.cnrm.cloud.google.com/v1beta1
kind: BigQueryDataTransferConfig
metadata:
name: bigquerydatatransferconfig-sample-scheduledquery
spec:
projectRef:
# Replace ${PROJECT_ID?} with your project ID.
external: ${PROJECT_ID?}
location: us-central1
displayName: "example of scheduled query"
dataSourceID: "scheduled_query"
datasetRef:
name: bigquerydatatransferconfigdepscheduledquery
params:
destination_table_name_template: "my_table"
write_disposition: "WRITE_APPEND"
query: "SELECT name FROM tabl WHERE x = 'y'"
schedule: "first sunday of quarter 00:00"
serviceAccountRef:
name: gsa-dep-scheduledquery
---
apiVersion: bigquery.cnrm.cloud.google.com/v1beta1
kind: BigQueryDataset
metadata:
name: bigquerydatatransferconfigdepscheduledquery
spec:
friendlyName: bigquerydatatransferconfig-dep-scheduledquery
location: us-central1
---
apiVersion: iam.cnrm.cloud.google.com/v1beta1
kind: IAMServiceAccount
metadata:
annotations:
# Replace ${PROJECT_ID?} with your project ID.
cnrm.cloud.google.com/project-id: "${PROJECT_ID?}"
name: gsa-dep-scheduledquery