Halaman ini menjelaskan cara menggunakan Tampilan BigQuery untuk AlloyDB guna mengimpor data dari BigQuery, termasuk tabel native, tabel eksternal BigLake, dan tabel terkelola Apache Iceberg. Iceberg adalah format tabel terbuka untuk mengelola dan menukar data.
Halaman ini mengasumsikan bahwa Anda memiliki cluster dan instance utama AlloyDB, serta memiliki set data dan tabel BigQuery. Untuk mengetahui informasi selengkapnya, lihat Membuat set data dan Membuat dan menggunakan tabel.
Sebelum memulai
- Minta akses ke fitur BigQueryViews untuk cluster Anda dan tunggu hingga Anda menerima konfirmasi pengaktifan sebelum mengikuti petunjuk di halaman ini.
- Pahami Jenis data BigQuery dan pemetaan kolom yang didukung.
- Login ke akun Google Cloud Anda. Jika Anda baru menggunakan Google Cloud, buat akun untuk mengevaluasi performa produk kami dalam skenario dunia nyata. Pelanggan baru juga mendapatkan kredit gratis senilai $300 untuk menjalankan, menguji, dan men-deploy workload.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
Enable the AlloyDB, Compute Engine, Resource Manager, and BigQuery APIs.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
Enable the AlloyDB, Compute Engine, Resource Manager, and BigQuery APIs.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.-
Aktifkan Cloud API yang diperlukan untuk membuat dan menghubungkan ke AlloyDB untuk PostgreSQL.
Pada langkah Confirm project, klik Next untuk mengonfirmasi nama project yang akan Anda ubah.
Pada langkah Enable APIs, klik Enable untuk mengaktifkan berikut ini:
- AlloyDB API
- Compute Engine API
- Cloud Resource Manager API
- Service Networking API
- BigQuery Storage API
Service Networking API diperlukan jika Anda berencana mengonfigurasi konektivitas jaringan ke AlloyDB menggunakan jaringan VPC yang berada di project yang sama Google Cloud dengan AlloyDB.
Compute Engine API dan Cloud Resource Manager API diperlukan jika Anda berencana mengonfigurasi konektivitas jaringan ke AlloyDB menggunakan jaringan VPC yang berada di project Google Cloud lain.
Peran yang diperlukan
Untuk memberikan akses baca ke Set Data BigQuery bagi akun layanan cluster AlloyDB, Anda memerlukan izin berikut:
- BigQuery Data Viewer
(
roles/bigquery.dataViewer) atau peran kustom apa pun dengan izinbigquery.tables.getdanbigquery.tables.getData. Jika diberikan pada tabel atau tampilan, peran ini memberikan izin untuk membaca data dan metadata dari tabel atau tampilan. - BigQuery Read Session User
(
roles/bigquery.readSessionUser) atau peran kustom apa pun dengan izinbigquery.readsessions.createdanbigquery.readsessions.getData. Memberikan kemampuan untuk membuat dan menggunakan sesi baca.
Memberikan akses AlloyDB ke set data BigQuery
Setelah fitur Tampilan BigQuery diaktifkan di cluster AlloyDB, berikan akses akun layanan cluster AlloyDB ke set data BigQuery.
Untuk menggunakan gcloud CLI, Anda dapat menginstal dan melakukan inisialisasi Google Cloud CLI, atau Anda dapat menggunakan Cloud Shell.
Buka gcloud CLI. Jika Anda belum menginstal gcloud CLI, instal dan lakukan inisialisasi gcloud CLI, atau gunakan Cloud Shell.
Jalankan perintah
gcloud beta alloydb clusters describe:gcloud beta alloydb clusters describe CLUSTER --region=REGIONGanti kode berikut:
CLUSTER: ID cluster AlloyDB.REGION: lokasi cluster AlloyDB, misalnya,asia-east1,us-east1. Lihat daftar lengkap region di Mengelola lokasi instance.
Output-nya berisi kolom
serviceAccountEmail, yang merupakan akun layanan untuk cluster ini.Berikan izin yang diperlukan. Untuk mengetahui informasi selengkapnya, lihat Mengontrol akses ke resource dengan IAM.
Jika akun layanan cluster tidak memiliki izin yang diperlukan, error berikut akan muncul saat kueri dijalankan terhadap tabel BigQuery:
The user does not have bigquery.readsessions.create permissionsPermission bigquery.tables.get denied on tablePermission bigquery.tables.getData denied on table
Mengonfigurasi ekstensi
Buat ekstensi.
- Hubungkan ke instance AlloyDB menggunakan klien psql dengan mengikuti petunjuk di Menghubungkan klien psql ke instance. Atau, Anda dapat menggunakan AlloyDB Studio. Untuk mengetahui informasi selengkapnya, lihat Mengelola data Anda menggunakan konsol Google Cloud .
Jalankan perintah berikut:
CREATE EXTENSION bigquery_fdw;
Buat server asing untuk menentukan parameter koneksi untuk set data BigQuery jarak jauh.
CREATE SERVER BIGQUERY_SERVER_NAME FOREIGN DATA WRAPPER bigquery_fdw;Ganti kode berikut:
BIGQUERY_SERVER_NAME: ID unik untuk server asing. Tentukan ini sekali dalam database tertentu. Anda dapat menggantiBIGQUERY_SERVER_NAMEdengan nama server Anda.
Buat pemetaan pengguna dengan menjalankan perintah
CREATE USER MAPPING, yang menentukan kredensial yang akan digunakan saat Anda terhubung ke server asing.CREATE USER MAPPING FOR USERNAME SERVER BIGQUERY_SERVER_NAME ;Ganti kode berikut:
USERNAME: nama pengguna database atau pengguna IAM yang mengakses tabel asing.BIGQUERY_SERVER_NAME: ID unik untuk server asing yang Anda buat.
Tentukan tabel asing yang sesuai dengan tabel yang ingin Anda akses di BigQuery menggunakan perintah
CREATE FOREIGN TABLE. Perintah ini memungkinkan Anda menentukan struktur tabel jarak jauh. Tabel asing dapat memiliki semua atau sebagian kolom dalam tabel sumber di BigQuery.CREATE FOREIGN TABLE TABLENAME ( COLUMNX_NAME DATA_TYPE, COLUMNX_NAME DATA_TYPE, ... ) SERVER BIGQUERY_SERVER_NAME OPTIONS (project BIGQUERY_PROJECT_ID, dataset BIGQUERY_DATASET_NAME, table BIGQUERY_TABLE_NAME);Ganti kode berikut:
TABLENAME: nama tabel asing dalam database lokal.COLUMNX_NAME: nama kolom harus cocok dengan nama kolom di sumber BigQuery.DATA_TYPE: jenis data kolom.BIGQUERY_SERVER_NAME: ID unik untuk server asing yang Anda buat.BIGQUERY_PROJECT_ID: ID project tempat set data BigQuery berada.BIGQUERY_DATASET_NAME: nama set data BigQuery untuk tabel.BIGQUERY_TABLE_NAME: nama tabel BigQuery.
Setelah tabel asing dibuat, Anda dapat membuat kueri tabel ini dengan cara yang sama seperti saat membuat kueri tabel apa pun di AlloyDB.
Mengimpor data
Untuk mengimpor data BigQuery atau data Iceberg BigLake ke AlloyDB, ikuti langkah-langkah berikut:
Identifikasi sumber data yang ada atau buat tabel BigQuery native atau tabel terkelola Iceberg baru.
Gunakan psql untuk membuat
local_tabledengan menjalankan perintah berikut:CREATE TABLE local_table AS (SELECT * from foreign_table);Perintah ini membuat salinan tabel BigQuery ke tabel AlloyDB lokal dan native.
Bergantung pada alur kerja aplikasi, Anda dapat mengonfigurasi ekstensipg_cronPostgreSQL untuk memperbarui tabel AlloyDB secara berkala.
Menyiapkan jadwal untuk mengimpor data ke AlloyDB
Untuk menyiapkan jadwal guna mengimpor data BigQuery atau data Iceberg BigLake ke AlloyDB, ikuti langkah-langkah berikut:
- Konfigurasi ekstensi
bigquery_fdw. - Aktifkan ekstensi
pg_crondi instance AlloyDB. Untuk mengetahui informasi selengkapnya, lihat Ekstensi database yang didukung.- Tetapkan flag
alloydb.enable_pg_cronkeon. Untuk mengetahui informasi selengkapnya, lihat alloydb.enable_pg_cron. - Tetapkan flag
cron.database_nameke nama database tempat Anda menginstal ekstensibigquery_fdw, dan tempat Anda ingin menjalankan kueri SQL untuk impor. Untuk mengetahui informasi selengkapnya, lihat Flag database yang didukung.
- Tetapkan flag
Untuk memuat ulang salinan lokal tabel asing secara berkala, jalankan perintah berikut di database tempat Anda menginstal ekstensi
bigquery_fdw:CREATE EXTENSION pg_cron; SELECT cron.schedule(JOB_NAME, SCHEDULE, 'CREATE TABLE IF NOT EXISTS local_table_copy AS (SELECT * FROM foreign_table); DROP TABLE IF EXISTS local_table; ALTER TABLE local_table_copy RENAME TO local_table;');Ganti kode berikut:
JOB_NAME: nama tugas.SCHEDULE: jadwal untuk tugas.
Untuk mengetahui informasi selengkapnya, lihat Apa itu pg_cron?.
Langkah berikutnya
- Pelajari kasus penggunaan untuk mengakses data BigQuery dari AlloyDB.
- Mengakses data BigQuery dari AlloyDB.
- Pelajari jenis data BigQuery dan pemetaan kolom yang didukung.