Dokumen ini menjelaskan cara membuat dan mengisi ulang embedding vektor secara massal untuk data tekstual (STRING atau JSON) yang disimpan di Spanner menggunakan SQL dan model embedding teks Platform Agen Gemini Enterprise.
Prasyarat
Anda harus memiliki tabel di database Spanner yang berisi data tekstual (STRING atau JSON). Untuk mengetahui informasi selengkapnya tentang mengimpor data, lihat Ringkasan impor dan ekspor Spanner.
Contoh kasus penggunaan
Misalkan Anda memiliki tabel di Spanner dengan skema berikut. Tabel ini berisi jutaan catatan.
GoogleSQL
CREATE TABLE Products (
product_id INT64 NOT NULL,
name STRING(MAX),
description STRING(MAX)
) PRIMARY KEY(product_id);
PostgreSQL
CREATE TABLE Products (
product_id INT8 NOT NULL,
name TEXT,
description TEXT,
PRIMARY KEY(product_id)
);
Tujuan Anda adalah membuat embedding vektor untuk kolom description dalam tabel ini untuk menemukan item serupa yang akan direkomendasikan kepada pelanggan guna meningkatkan pengalaman berbelanja mereka menggunakan penelusuran vektor.
Mendaftarkan model embedding
GoogleSQL
Daftarkan model embedding teks dengan endpoint model Agent Platform di database Spanner Anda:
CREATE MODEL MODEL_NAME
INPUT(
content STRING(MAX)
)
OUTPUT(
embeddings STRUCT<values ARRAY<FLOAT32>>
)
REMOTE OPTIONS(
endpoint = '//aiplatform.googleapis.com/projects/PROJECT/locations/LOCATION/publishers/google/models/$MODEL_NAME',
default_batch_size = 5
)
Ganti kode berikut:
MODEL_NAME: nama model penyematan teks Agent PlatformPROJECT: project yang menghosting endpoint Agent PlatformLOCATION: lokasi endpoint Agent Platform
PostgreSQL
Dalam dialek PostgreSQL, tidak perlu mendaftarkan model.
Anda meneruskan nama endpoint langsung ke panggilan fungsi spanner.ML_PREDICT_ROW.
Untuk praktik terbaik, pertimbangkan hal berikut:
- Untuk mempertahankan isolasi kuota, gunakan endpoint di project yang berbeda untuk membuat dan mengisi ulang penyematan daripada endpoint produksi. Cadangkan endpoint produksi untuk menyalurkan traffic produksi.
- Pastikan endpoint model mendukung nilai
default_batch_size. Anda dapat menggantidefault_batch_sizedengan petunjuk kueri@{remote_udf_max_rows_per_rpc=NEW_NUMBER}. Untuk mengetahui informasi tentang batasdefault_batch_sizeuntuk setiap region, lihat Mendapatkan embedding teks untuk cuplikan teks. - Tentukan endpoint dengan versi model tertentu (misalnya,
@003) dan bukan@latest. Hal ini karena vektor sematan yang dihasilkan untuk potongan teks yang sama mungkin berbeda, bergantung pada versi model yang Anda gunakan. Oleh karena itu, Anda sebaiknya menghindari penggunaan versi model yang berbeda untuk menghasilkan sematan dalam set data yang sama. Selain itu, memperbarui versi model dalam pernyataan definisi model tidak akan memperbarui sematan yang sudah dibuat dengan model ini. Salah satu cara untuk mengelola versi model untuk penyematan adalah dengan membuat kolom tambahan dalam tabel yang menyimpan versi model. - Model penyematan teks yang disesuaikan tidak didukung dengan fungsi
ML.PREDICTGoogleSQL danspanner.ML_PREDICT_ROWPostgreSQL.
Menguji integrasi model embedding secara menyeluruh
Anda dapat menjalankan kueri untuk menguji apakah model embedding berhasil dikonfigurasi, dan embedding diambil. Misalnya, jalankan kueri berikut:
GoogleSQL
SELECT embeddings.values
FROM SAFE.ML.PREDICT(
MODEL MODEL_NAME,
(SELECT description AS content FROM products LIMIT 10)
);
Ganti kode berikut:
MODEL_NAME: nama model penyematan teks Agent Platform
PostgreSQL
SELECT spanner.ML_PREDICT_ROW(
'projects/PROJECT/locations/LOCATION/publishers/google/models/$MODEL_NAME',
JSONB_BUILD_OBJECT('instances', JSONB_BUILD_ARRAY(JSONB_BUILD_OBJECT('content', description))))
FROM Products
LIMIT 10;
Ganti kode berikut:
PROJECT: project yang menghosting endpoint Agent PlatformLOCATION: lokasi endpoint Agent PlatformMODEL_NAME: nama model penyematan teks Agent Platform
Perbarui tabel sumber untuk menyertakan kolom tambahan guna menyimpan embedding
Selanjutnya, perbarui skema tabel sumber untuk menyertakan kolom tambahan dengan
jenis data ARRAY<FLOAT32> untuk menyimpan embedding yang dihasilkan:
GoogleSQL
ALTER TABLE TABLE_NAME
ADD COLUMN EMBEDDING_COLUMN_NAME ARRAY<FLOAT32>;
Ganti kode berikut:
TABLE_NAME: nama tabel sumberEMBEDDING_COLUMN_NAME: nama kolom tempat Anda ingin menambahkan embedding yang dihasilkan
PostgreSQL
ALTER TABLE TABLE_NAME
ADD COLUMN EMBEDDING_COLUMN_NAME real[];
Ganti kode berikut:
TABLE_NAME: nama tabel sumberEMBEDDING_COLUMN_NAME: nama kolom tempat Anda ingin menambahkan embedding yang dihasilkan
Misalnya, menggunakan contoh tabel products, jalankan:
GoogleSQL
ALTER TABLE Products
ADD COLUMN desc_embed ARRAY<FLOAT32>;
PostgreSQL
ALTER TABLE Products
ADD COLUMN desc_embed real[];
Anda dapat menambahkan kolom lain untuk mengelola versi model penyematan.
GoogleSQL
ALTER TABLE Products
ADD COLUMN desc_embed_model_version INT64;
PostgreSQL
ALTER TABLE Products
ADD COLUMN desc_embed_model_version INT8;
Menambah kuota untuk Agent Platform
Anda mungkin perlu menambah kuota Agent Platform API untuk region yang menggunakan model embedding teks. Untuk meminta penambahan kuota, lihat Penambahan kuota Platform Agen.
Embedding pengisian ulang
Terakhir, jalankan pernyataan UPDATE berikut menggunakan DML berpartisi
untuk membuat embedding bagi kolom data tekstual dan menyimpan embedding
dalam database Anda. Anda dapat menyimpan versi model bersama dengan embedding. Sebaiknya jalankan kueri ini selama periode traffic rendah di database Anda.
GoogleSQL
UPDATE TABLE_NAME
SET
TABLE_NAME.EMBEDDING_COLUMN_NAME = (
SELECT embeddings.values
FROM SAFE.ML.PREDICT(
MODEL MODEL_NAME,
(SELECT TABLE_NAME.DATA_COLUMN_NAME AS content)
) @{remote_udf_max_rows_per_rpc=MAX_ROWS}
),
TABLE_NAME.EMBEDDING_VERSION_COLUMN = MODEL_VERSION
WHERE FILTER_CONDITION;
Ganti kode berikut:
TABLE_NAME: nama tabel dengan data tekstualEMBEDDING_COLUMN_NAME: nama kolom tempat Anda ingin menambahkan embedding yang dihasilkanDATA_COLUMN_NAME: nama kolom dengan data tekstualMODEL_NAME: nama model sematan Agent PlatformMAX_ROWS: jumlah maksimum baris per RPCEMBEDDING_VERSION_COLUMN: kolom yang mengelola versi model embedding yang digunakan untuk mengisi ulang embedding AndaMODEL_VERSION: versi model penyematan teksFILTER_CONDITION: kondisi filter dapat dipartisi yang ingin Anda terapkan
Penggunaan SAFE.ML.PREDICT menampilkan NULL untuk permintaan yang gagal. Anda juga dapat menggunakan
SAFE.ML.PREDICT bersama dengan filter WHERE embedding_column IS NULL
untuk menjalankan kembali kueri tanpa menghitung sematan untuk kolom
yang sudah dihitung.
PostgreSQL
UPDATE TABLE_NAME
SET
EMBEDDING_COLUMN_NAME = spanner.FLOAT32_ARRAY(spanner.ML_PREDICT_ROW(
'projects/PROJECT/locations/LOCATION/publishers/google/models/$MODEL_NAME',
JSONB_BUILD_OBJECT('instances', JSONB_BUILD_ARRAY(JSONB_BUILD_OBJECT('content', DATA_COLUMN_NAME)))
) /*@ remote_udf_max_rows_per_rpc=MAX_ROWS */ ->'predictions'->0->'embeddings'->'values'),
EMBEDDING_VERSION_COLUMN = MODEL_VERSION
WHERE FILTER_CONDITION;
Ganti kode berikut:
TABLE_NAME: nama tabel dengan data tekstualEMBEDDING_COLUMN_NAME: nama kolom tempat Anda ingin menambahkan embedding yang dihasilkanDATA_COLUMN_NAME: nama kolom dengan data tekstualPROJECT: project yang menghosting endpoint Agent PlatformLOCATION: lokasi endpoint Agent PlatformMODEL_NAME: nama model sematan Agent PlatformMODEL_VERSION: versi model sematan Agent PlatformMAX_ROWS: jumlah maksimum baris per RPCEMBEDDING_VERSION_COLUMN: kolom yang mengelola versi model penyematan teks yang digunakan untuk mengisi ulang penyematan AndaFILTER_CONDITION: kondisi filter dapat dipartisi yang ingin Anda terapkan
Contoh kueri pengisian ulang untuk tabel products:
GoogleSQL
UPDATE products
SET
products.desc_embed = (
SELECT embeddings.values
FROM SAFE.ML.PREDICT(
MODEL embedding_model,
(SELECT products.description AS content)
) @{remote_udf_max_rows_per_rpc=200}
),
products.desc_embed_model_version = 3
WHERE products.desc_embed IS NULL;
PostgreSQL
UPDATE products
SET
desc_embed = spanner.FLOAT32_ARRAY(spanner.ML_PREDICT_ROW(
'projects/PROJECT/locations/LOCATION/publishers/google/models/$MODEL_NAME',
JSONB_BUILD_OBJECT('instances', JSONB_BUILD_ARRAY(JSONB_BUILD_OBJECT('content', description)))
) /*@ remote_udf_max_rows_per_rpc=200 */ ->'predictions'->0->'embeddings'->'values'),
desc_embed_model_version = 3
WHERE desc_embed IS NULL;
Untuk praktik terbaik, pertimbangkan hal berikut:
- Waktu tunggu gRPC default untuk Spanner API adalah satu jam.
Bergantung pada jumlah penyematan yang Anda isi ulang, Anda mungkin perlu
meningkatkan waktu tunggu ini untuk memastikan DML berpartisi
UPDATEmemiliki waktu yang cukup untuk diselesaikan. Untuk mengetahui informasi selengkapnya, lihat Mengonfigurasi waktu tunggu dan percobaan ulang kustom.
Performa dan pertimbangan lainnya
Pertimbangkan hal berikut untuk mengoptimalkan performa saat mengisi ulang data penyematan.
Jumlah node
DML yang dipartisi menjalankan pernyataan DML yang diberikan pada partisi yang berbeda secara paralel. Untuk instance dengan jumlah node yang tinggi, Anda mungkin melihat error kuota selama eksekusi DML berpartisi. Jika permintaan Agent Platform API dibatasi karena batas kuota Agent Platform API, Spanner akan mencoba kembali kegagalan ini dalam mode transaksi DML yang dipartisi hingga maksimal 20 kali. Jika Anda mengamati tingkat error kuota yang tinggi di Agent Platform, tingkatkan kuota untuk Agent Platform.
Anda juga dapat menyesuaikan paralelisme menggunakan petunjuk tingkat pernyataan
@{pdml_max_parallelism=DESIRED_NUMBER} saat menggunakan GoogleSQL. Contoh
berikut menyetel paralelisme ke '5':
GoogleSQL
@{pdml_max_parallelism=5} UPDATE products
SET products.desc_embed =(
SELECT embeddings.values
FROM SAFE.ML.PREDICT(MODEL embedding_model, (
SELECT products.value AS CONTENT
)
)
@{remote_udf_max_rows_per_rpc=200}
),
products.desc_embed_model_version = MODEL_VERSION
WHERE products.desc_embed IS NULL;
Ukuran teks dalam kolom data
Model sematan Platform Agen memiliki batasan jumlah maksimum token untuk setiap input teks. Versi model yang berbeda memiliki batas token yang berbeda. Setiap permintaan Agent Platform dapat memiliki beberapa kolom
input teks, tetapi ada batasan jumlah maksimum token yang ada
dalam satu permintaan. Untuk database GoogleSQL, jika Anda mengalami error
INVALID_ARGUMENT dengan pesan "Permintaan terlalu besar", coba kurangi
ukuran batch untuk menghindari error. Untuk melakukannya, Anda dapat mengonfigurasi default_batch_size
atau menggunakan petunjuk kueri @{remote_udf_max_outstanding_rpcs} saat mendaftarkan model.
Jumlah permintaan API yang dikirim ke Agent Platform
Anda dapat menggunakan petunjuk kueri @{remote_udf_max_outstanding_rpcs} untuk menambah atau
mengurangi jumlah permintaan yang dikirim ke Platform Agen dari
Spanner. Perlu diketahui bahwa meningkatkan batas ini dapat meningkatkan penggunaan CPU dan memori instance Spanner. Untuk database GoogleSQL, menggunakan petunjuk kueri ini akan menggantikan default_batch_size yang dikonfigurasi untuk model Anda.
Memantau progres pengisian ulang
Anda dapat memantau jumlah permintaan, latensi, dan byte jaringan yang dikirim ke Agent Platform dari Spanner menggunakan dasbor insight sistem.
Langkah berikutnya
- Pelajari cara melakukan penelusuran vektor kesamaan dengan menemukan K-nearest neighbors.
- Pelajari lebih lanjut machine learning dan embedding dalam kursus singkat tentang embedding kami.
- Pelajari lebih lanjut model embedding teks Platform Agen.