连接到 Blob Storage
作为 BigQuery 管理员,您可以创建一个连接,使数据分析师能够访问存储在 Blob Storage 中的数据。
BigQuery Omni 通过连接访问 Blob Storage 数据。 BigQuery Omni 支持 Azure 工作负载身份联合。借助 BigQuery Omni 对 Azure 工作负载身份联合的支持,您可以向 Google 服务账号授予对租户中的 Azure 应用的访问权限。您或 Google 无需管理应用客户端密钥。
创建 BigQuery Azure 连接后,您可以查询 Blob Storage 数据或将查询结果导出到 Blob Storage。
准备工作
确保您已创建以下资源:
一个启用了 BigQuery Connection API 的 Google Cloud 项目。
如果您使用的是基于容量的价格模式,请确保已为项目启用 BigQuery Reservation API。如需了解价格,请参阅 BigQuery Omni 价格。
具有 Azure 订阅的 Azure 租户。
符合以下规范的 Azure Storage 账号:
该账号是通用 V2 账号或 Blob Storage 账号。
它使用分层命名空间。如需了解详情,请参阅创建存储账号以与 Azure Data Lake Storage Gen2 搭配使用。
数据以一种支持的格式填充。
数据位于
azure-eastus2
区域。
所需的角色
-
如需获得创建连接以访问 Azure Blob Storage 数据所需的权限,请让您的管理员为您授予项目的 BigQuery Connection Admin (
roles/bigquery.connectionAdmin
) IAM 角色。如需详细了解如何授予角色,请参阅管理对项目、文件夹和组织的访问权限。 -
确保您对租户拥有以下 Azure IAM 权限:
Application.ReadWrite.All
AppRoleAssignment.ReadWrite.All
配额
如需详细了解配额,请参阅 BigQuery Connection API。
创建 Azure 连接
如需创建 Azure 来源,请按照以下步骤操作:
如需详细了解如何使用联合身份凭据访问 Azure 中的数据,请参阅工作负载身份联合。
在 Azure 租户中创建应用
如需在 Azure 租户中创建应用,请按照以下步骤操作:
Azure 门户
在 Azure 门户中,转到应用注册,然后点击新注册。
对于名称,请输入应用的名称。
对于 Supported account types(支持的账号类型),选择 Accounts in this organizational directory only(仅此组织目录中的账号)。
如需注册新应用,请点击注册。
记下 Application (client) ID(应用(客户端)ID)。创建连接时,您需要提供此 ID。
Terraform
将以下内容添加到 Terraform 配置文件中:
resource "azuread_application" "example" { display_name = "bigquery-omni-connector" } resource "azuread_service_principal" "example" { application_id = azuread_application.example.application_id app_role_assignment_required = false }
如需了解详情,请参阅如何在 Azure 中注册应用。
创建连接
控制台
在 Google Cloud 控制台中,转到 BigQuery 页面。
在
添加数据菜单中,选择外部数据源。在外部数据源窗格中,输入以下信息:
- 对于连接类型,选择 Azure 上的 BigLake(通过 BigQuery Omni)。
- 对于连接 ID,输入连接资源的标识符。可使用字母、数字、短划线和下划线。
- 选择您要在其中创建连接的位置。
- 可选:对于易记名称,输入方便用户使用的连接名称,例如
My connection resource
。易记名称可以是任何容易辨识的值,让您以后在需要修改连接资源时能够轻松识别。 - 可选:对于说明,输入此连接资源的说明。
- 对于 Azure 租户 ID,输入 Azure 租户 ID,也称为目录(租户)ID。
选中使用联合身份复选框,然后输入 Azure 联合应用(客户端)ID。
如需了解如何获取 Azure ID,请参阅在 Azure 租户中创建应用。
点击创建连接。
点击转到连接。
在连接信息部分中,记下 BigQuery Google 身份的值,即服务账号 ID。此 ID 适用于您授权其访问应用的 Google Cloud 服务账号。
Terraform
resource "google_bigquery_connection" "connection" { connection_id = "omni-azure-connection" location = "azure-eastus2" description = "created by terraform" azure { customer_tenant_id = "TENANT_ID" federated_application_client_id = azuread_application.example.application_id } }
将 TENANT_ID
替换为包含 Blob Storage 账号的 Azure 目录的租户 ID。
bq
使用 bq mk
命令。 如需获取采用 JSON 格式的输出,请使用 --format=json
参数。
bq mk --connection --connection_type='Azure' \ --tenant_id=TENANT_ID \ --location=AZURE_LOCATION \ --federated_azure=true \ --federated_app_client_id=APP_ID \ CONNECTION_ID
替换以下内容:
TENANT_ID
:包含 Azure Storage 账号的 Active Directory 的租户 ID。AZURE_LOCATION
:Azure Storage 数据所在的 Azure 区域。BigQuery Omni 支持azure-eastus2
区域。APP_ID
:Azure 应用(客户端)ID。如需了解如何获取此 ID,请参阅在 Azure 租户中创建应用。CONNECTION_ID
:连接的名称。
输出类似于以下内容:
Connection CONNECTION_ID successfully created Please add the following identity to your Azure application APP_ID Identity: SUBJECT_ID
此输出包括以下值:
APP_ID
:您创建的应用的 ID。SUBJECT_ID
:用户授权其访问应用的 Google Cloud 服务账号的 ID。在 Azure 中创建联合凭据时,此值是必需的。
请记下 APP_ID
和 SUBJECT_ID
值,以便在后续步骤中使用。
接下来,为您的应用添加联合凭据。
添加联合凭据
如需创建联合凭据,请按照以下步骤操作:
Azure 门户
在 Azure 门户中,转到应用注册,然后点击您的应用。
选择“Certificates & secrets”(证书和密钥)>“Federated credentials”(联合凭据)> 添加凭据。之后,执行以下操作:
从 Federated credential scenario(联合凭据场景)列表中,选择 Other issuer(其他颁发者)。
对于颁发者,输入
https://accounts.google.com
。对于 Subject identifier(使用者标识符),输入您在创建连接时获得的 Google Cloud 服务账号的 BigQuery Google 身份。
对于名称,输入凭据的名称。
点击添加。
Terraform
将以下内容添加到 Terraform 配置文件中:
resource "azuread_application" "example" { display_name = "bigquery-omni-connector" } resource "azuread_service_principal" "example" { application_id = azuread_application.example.application_id app_role_assignment_required = false } resource "azuread_application_federated_identity_credential" "example" { application_object_id = azuread_application.example.object_id display_name = "omni-federated-credential" description = "BigQuery Omni federated credential" audiences = ["api://AzureADTokenExchange"] issuer = "https://accounts.google.com" subject = google_bigquery_connection.connection.azure[0].identity }
如需了解详情,请参阅将应用配置为信任外部身份提供方。
为 BigQuery 的 Azure 应用分配角色
如需为 BigQuery 的 Azure 应用分配角色,请使用 Azure 门户、Azure PowerShell 或 Microsoft Management REST API:
Azure 门户
您可以具有 Microsoft.Authorization/roleAssignments/write
权限的用户身份登录 Azure 门户,以在该门户中执行角色分配。通过角色分配,BigQuery Azure 连接可以访问角色政策中指定的 Azure Storage 数据。
如需使用 Azure 门户添加角色分配,请按照以下步骤操作:
从 Azure Storage 账号,在搜索栏中输入
IAM
。点击 Access Control (IAM)(访问权限控制 (IAM))。
点击添加,然后选择添加角色分配。
如需提供只读权限,请选择 Storage Blob Data Reader 角色。如需提供读写权限,请选择 Storage Blob Data Contributor 角色。
将分配权限设置为用户、群组或服务主账号。
点击选择成员。
在选择字段中,输入您在 Azure 租户中创建应用时提供的 Azure 应用名称。
点击保存。
如需了解详情,请参阅使用 Azure 门户分配 Azure 角色。
Terraform
将以下内容添加到 Terraform 配置文件中:
resource "azurerm_role_assignment" "data-role" { scope = data.azurerm_storage_account.example.id # Read permission for Omni on the storage account role_definition_name = "Storage Blob Data Reader" principal_id = azuread_service_principal.example.id }
Azure PowerShell
如需在资源范围内为服务主账号添加角色分配,您可以使用 New-AzRoleAssignment
命令:
New-AzRoleAssignment` -SignInName APP_NAME` -RoleDefinitionName ROLE_NAME` -ResourceName RESOURCE_NAME` -ResourceType RESOURCE_TYPE` -ParentResource PARENT_RESOURCE` -ResourceGroupName RESOURCE_GROUP_NAME
请替换以下内容:
APP_NAME
:应用名称。ROLE_NAME
:您要分配的角色名称。RESOURCE_NAME
:资源名称。RESOURCE_TYPE
:资源类型。PARENT_RESOURCE
:父级资源。RESOURCE_GROUP_NAME
:资源组名称。
如需详细了解如何使用 Azure PowerShell 添加新的服务主账号,请参阅使用 Azure PowerShell 分配 Azure 角色。
Azure CLI
如需在资源范围内为服务主账号添加角色分配,您可以使用 Azure 命令行工具。您必须拥有存储账号的 Microsoft.Authorization/roleAssignments/write
权限才能授予角色。
如需向服务主账号分配角色(例如 Storage Blob Data Reader 角色),请运行 az role assignment create
命令:
az role assignment create --role "Storage Blob Data Reader" \ --assignee-object-id ${SP_ID} \ --assignee-principal-type ServicePrincipal \ --scope subscriptions/SUBSCRIPTION_ID/resourcegroups/RESOURCE_GROUP_NAME/providers/Microsoft.Storage/storageAccounts/STORAGE_ACCOUNT_NAME
替换以下内容:
SP_ID
:服务主账号 ID。此服务主账号适用于您创建的应用。如需获取联合连接的服务主账号,请参阅服务主账号对象。STORAGE_ACCOUNT_NAME
:存储账号名称。RESOURCE_GROUP_NAME
:资源组名称。SUBSCRIPTION_ID
:订阅 ID。
如需了解详情,请参阅使用 Azure CLI 分配 Azure 角色。
Microsoft REST API
如需为服务主账号添加角色分配,您可以向 Microsoft Management 发送 HTTP 请求。
如需调用 Microsoft Graph REST API,请检索应用的 OAuth 令牌。如需了解详情,请参阅在没有用户的情况下获取访问权限。调用 Microsoft Graph REST API 的应用必须具有 Application.ReadWrite.All
应用权限。
如需生成 OAuth 令牌,请运行以下命令:
export TOKEN=$(curl -X POST \ https://login.microsoftonline.com/TENANT_ID/oauth2/token \ -H 'cache-control: no-cache' \ -H 'content-type: application/x-www-form-urlencoded' \ --data-urlencode "grant_type=client_credentials" \ --data-urlencode "resource=https://graph.microsoft.com/" \ --data-urlencode "client_id=CLIENT_ID" \ --data-urlencode "client_secret=CLIENT_SECRET" \ | jq --raw-output '.access_token')
请替换以下内容:
TENANT_ID
:与包含 Azure Storage 账号的 Azure 目录的 ID 匹配的租户 ID。CLIENT_ID
:Azure 客户端 ID。CLIENT_SECRET
:Azure 客户端密钥。
获取要为服务主账号分配的 Azure 内置角色的 ID。
以下是一些常见角色:
- Storage Blob Data Contributor:
ba92f5b4-2d11-453d-a403-e96b0029c9fe
- Storage Blob Data Reader:
2a2b9908-6ea1-4ae2-8e65-a410df84e7d1
如需为服务主账号分配角色,请针对 Azure Resource Management REST API 调用 Microsoft Graph REST API:
export ROLE_ASSIGNMENT_ID=$(uuidgen) curl -X PUT \ 'https://management.azure.com/subscriptions/SUBSCRIPTION_ID/resourcegroups/RESOURCE_GROUP_NAME/providers/Microsoft.Storage/storageAccounts/STORAGE_ACCOUNT_NAME/providers/Microsoft.Authorization/roleAssignments/ROLE_ASSIGNMENT_ID?api-version=2018-01-01-preview' \ -H "authorization: Bearer ${TOKEN?}" \ -H 'cache-control: no-cache' \ -H 'content-type: application/json' \ -d '{ "properties": { "roleDefinitionId": "subscriptions/SUBSCRIPTION_ID/resourcegroups/RESOURCE_GROUP_NAME/providers/Microsoft.Storage/storageAccounts/STORAGE_ACCOUNT_NAME/providers/Microsoft.Authorization/roleDefinitions/ROLE_ID", "principalId": "SP_ID" } }'
请替换以下内容:
连接现在可以使用了。但是,Azure 中的角色分配可能存在传播延迟。如果您由于权限问题而无法使用连接,请稍后重试。
与用户共享连接
您可以授予以下角色,以使用户可以查询数据并管理连接:
roles/bigquery.connectionUser
:允许用户使用连接与外部数据源建立连接,并对其运行查询。roles/bigquery.connectionAdmin
:允许用户管理连接。
如需详细了解 BigQuery 中的 IAM 角色和权限,请参阅预定义的角色和权限。
从下列选项中选择一项:
控制台
转到 BigQuery 页面。
连接列在项目的外部连接组中。
在探索器窗格中,点击您的项目名称 > 外部连接 > 连接。
在详细信息窗格中,点击共享以共享连接。之后,执行以下操作:
在连接权限对话框中,通过添加或修改主账号与其他主账号共享连接。
点击保存。
bq
您不能使用 bq 命令行工具共享连接。如需共享连接,请使用 Google Cloud 控制台或 BigQuery Connections API 方法共享连接。
API
使用 BigQuery Connections REST API 参考文档部分中的 projects.locations.connections.setIAM
方法,并提供一个 policy
资源实例。
Java
试用此示例之前,请按照 BigQuery 快速入门:使用客户端库中的 Java 设置说明进行操作。 如需了解详情,请参阅 BigQuery Java API 参考文档。
如需向 BigQuery 进行身份验证,请设置应用默认凭据。 如需了解详情,请参阅为客户端库设置身份验证。
后续步骤
- 了解不同的连接类型。
- 了解如何管理连接。
- 详细了解 BigQuery Omni。
- 了解 BigLake 表。
- 了解如何查询 Blob Storage 数据。
- 了解如何将查询结果导出到 Blob Storage。