跳转到内容

Google Cloud SQL for PostgreSQL - `PostgresVectorStore`

云 SQL 是一项全托管式关系型数据库服务,提供高性能、无缝集成和卓越的可扩展性。它支持 MySQL、PostgreSQL 和 SQL Server 数据库引擎。通过 Cloud SQL 的 LlamaIndex 集成,扩展您的数据库应用程序以构建支持人工智能的体验。

本笔记本介绍如何使用 Cloud SQL for PostgreSQL 通过 PostgresVectorStore 类存储向量嵌入。

了解更多关于该软件包的信息,请访问 GitHub

Open In Colab

要运行此笔记本,您需要执行以下操作:

安装集成库 llama-index-cloud-sql-pg 以及嵌入服务库 llama-index-embeddings-vertex

%pip install --upgrade --quiet llama-index-cloud-sql-pg llama-index-embeddings-vertex llama-index-llms-vertex llama-index

仅限 Colab:取消注释以下单元格以重启内核,或使用按钮重启内核。对于 Vertex AI Workbench,您可以使用顶部的按钮重启终端。

# # Automatically restart kernel after installs so that your environment can access the new packages
# import IPython
# app = IPython.Application.instance()
# app.kernel.do_shutdown(True)

以登录此笔记本的IAM用户身份验证到Google Cloud,以便访问您的Google Cloud项目。

  • 如果您正在使用 Colab 运行此笔记本,请使用下面的单元格并继续。
  • 如果您正在使用 Vertex AI Workbench,请查看此处的设置说明。
from google.colab import auth
auth.authenticate_user()

设置您的 Google Cloud 项目,以便在此笔记本中利用 Google Cloud 资源。

如果您不知道您的项目ID,请尝试以下方法:

  • 运行 gcloud config list
  • 运行 gcloud projects list
  • 查看支持页面:定位项目ID
# @markdown Please fill in the value below with your Google Cloud project ID and then run the cell.
PROJECT_ID = "my-project-id" # @param {type:"string"}
# Set the project id
!gcloud config set project {PROJECT_ID}

Cloud SQL 实例页面中查找您的数据库值。

# @title Set Your Values Here { display-mode: "form" }
REGION = "us-central1" # @param {type: "string"}
INSTANCE = "my-primary" # @param {type: "string"}
DATABASE = "my-database" # @param {type: "string"}
TABLE_NAME = "vector_store" # @param {type: "string"}
USER = "postgres" # @param {type: "string"}
PASSWORD = "my-password" # @param {type: "string"}

将 Cloud SQL 设为向量存储的要求和参数之一是 PostgresEngine 对象。PostgresEngine 用于配置与 Cloud SQL 数据库的连接池,使应用程序能够成功建立连接并遵循行业最佳实践。

要使用 PostgresEngine.from_instance() 创建 PostgresEngine,您只需提供以下4项内容:

  1. project_id : 云 SQL 实例所在的 Google Cloud 项目的项目 ID。
  2. region : Cloud SQL 实例所在的区域。
  3. instance : Cloud SQL 实例的名称。
  4. database : 要连接的 Cloud SQL 实例上的数据库名称。

默认情况下,IAM数据库认证将被用作数据库认证方法。该库使用属于来自环境的应用默认凭据(ADC)的IAM主体。

有关IAM数据库认证的更多信息,请参阅:

可选地,也可以使用内置数据库认证,通过用户名和密码访问 Cloud SQL 数据库。只需向 PostgresEngine.from_instance() 提供可选的 userpassword 参数:

  • useruser : 用于内置数据库认证和登录的数据库用户
  • passwordpassword : 用于内置数据库认证和登录的数据库密码。

注意: 本教程演示异步接口。所有异步方法都有对应的同步方法。

from llama_index_cloud_sql_pg import PostgresEngine
engine = await PostgresEngine.afrom_instance(
project_id=PROJECT_ID,
region=REGION,
instance=INSTANCE,
database=DATABASE,
user=USER,
password=PASSWORD,
)

PostgresVectorStore 类需要一个数据库表。PostgresEngine 引擎有一个辅助方法 init_vector_store_table(),可用于为您创建具有正确架构的表。

await engine.ainit_vector_store_table(
table_name=TABLE_NAME,
vector_size=768, # Vector size for VertexAI model(textembedding-gecko@latest)
)

您也可以通过在任何传递 table_name 的地方传递 schema_name 来指定架构名称。

SCHEMA_NAME = "my_schema"
await engine.ainit_vector_store_table(
table_name=TABLE_NAME,
schema_name=SCHEMA_NAME,
vector_size=768,
)

您可以使用任何Llama Index嵌入模型。 您可能需要启用Vertex AI API才能使用VertexTextEmbeddings。我们建议为生产环境设置嵌入模型的版本,了解更多关于文本嵌入模型的信息。

# enable Vertex AI API
!gcloud services enable aiplatform.googleapis.com
from llama_index.core import Settings
from llama_index.embeddings.vertex import VertexTextEmbedding
from llama_index.llms.vertex import Vertex
import google.auth
credentials, project_id = google.auth.default()
Settings.embed_model = VertexTextEmbedding(
model_name="textembedding-gecko@003",
project=PROJECT_ID,
credentials=credentials,
)
Settings.llm = Vertex(model="gemini-1.5-flash-002", project=PROJECT_ID)

初始化一个默认的 PostgresVectorStore

Section titled “Initialize a default PostgresVectorStore”
from llama_index_cloud_sql_pg import PostgresVectorStore
vector_store = await PostgresVectorStore.create(
engine=engine,
table_name=TABLE_NAME,
# schema_name=SCHEMA_NAME
)
!mkdir -p 'data/paul_graham/'
!wget 'https://raw.githubusercontent.com/run-llama/llama_index/main/docs/examples/data/paul_graham/paul_graham_essay.txt' -O 'data/paul_graham/paul_graham_essay.txt'
from llama_index.core import SimpleDirectoryReader
documents = SimpleDirectoryReader("./data/paul_graham").load_data()
print("Document ID:", documents[0].doc_id)

与 VectorStoreIndex 配合使用

Section titled “Use with VectorStoreIndex”

通过使用VectorStoreIndex从向量存储创建索引。

使用向量存储的最简单方法是加载一组文档,并使用from_documents从中构建索引。

from llama_index.core import StorageContext, VectorStoreIndex
storage_context = StorageContext.from_defaults(vector_store=vector_store)
index = VectorStoreIndex.from_documents(
documents, storage_context=storage_context, show_progress=True
)
query_engine = index.as_query_engine()
response = query_engine.query("What did the author do?")
print(response)

向量存储可以利用关系数据来筛选相似性搜索。

创建一个带有自定义元数据列的新表。 您也可以重用已包含文档ID、内容、嵌入和/或元数据的自定义列的现有表。

from llama_index_cloud_sql_pg import Column
# Set table name
TABLE_NAME = "vectorstore_custom"
# SCHEMA_NAME = "my_schema"
await engine.ainit_vector_store_table(
table_name=TABLE_NAME,
# schema_name=SCHEMA_NAME,
vector_size=768, # VertexAI model: textembedding-gecko@003
metadata_columns=[Column("len", "INTEGER")],
)
# Initialize PostgresVectorStore
custom_store = await PostgresVectorStore.create(
engine=engine,
table_name=TABLE_NAME,
# schema_name=SCHEMA_NAME,
metadata_columns=["len"],
)

文档 metadata 可以为LLM和检索过程提供更多信息。了解更多关于提取和添加元数据的不同方法。

from llama_index.core import Document
fruits = ["apple", "pear", "orange", "strawberry", "banana", "kiwi"]
documents = [
Document(text=fruit, metadata={"len": len(fruit)}) for fruit in fruits
]
storage_context = StorageContext.from_defaults(vector_store=custom_store)
custom_doc_index = VectorStoreIndex.from_documents(
documents, storage_context=storage_context, show_progress=True
)

你可以通过指定 filters 参数对搜索结果应用预过滤

from llama_index.core.vector_stores.types import (
MetadataFilter,
MetadataFilters,
FilterOperator,
)
filters = MetadataFilters(
filters=[
MetadataFilter(key="len", operator=FilterOperator.GT, value="5"),
],
)
query_engine = custom_doc_index.as_query_engine(filters=filters)
res = query_engine.query("List some fruits")
print(str(res.source_nodes[0].text))

通过应用向量索引加速向量搜索查询。了解更多关于向量索引的信息。

from llama_index_cloud_sql_pg.indexes import IVFFlatIndex
index = IVFFlatIndex()
await vector_store.aapply_vector_index(index)
await vector_store.areindex() # Re-index using default index name
await vector_store.adrop_vector_index() # Delete index using default name