AzureOpenAIEmbeddings 功能和配置选项的详细文档,请参阅 API 参考。
以前,LangChain.js 使用专用的 Azure OpenAI SDK 支持与 Azure OpenAI 集成。该 SDK 现已弃用,转而使用 OpenAI SDK 中的新 Azure 集成,后者允许在发布当天访问最新的 OpenAI 模型和功能,并允许在 OpenAI API 和 Azure OpenAI 之间无缝过渡。如果您正在使用已弃用的 SDK 与 Azure OpenAI,请参阅迁移指南以更新到新 API。
概述
集成详情
设置
要访问 Azure OpenAI 嵌入模型,您需要创建一个 Azure 帐户、获取 API 密钥,并安装@langchain/openai 集成包。
凭据
您需要部署一个 Azure OpenAI 实例。您可以按照此指南在 Azure 门户上部署一个版本。 实例运行后,请确保您拥有实例名称和密钥。您可以在 Azure 门户中实例的“密钥和终结点”部分下找到密钥。 如果您使用的是 Node.js,可以定义以下环境变量来使用该服务:安装
LangChain AzureOpenAIEmbeddings 集成位于@langchain/openai 包中:
您可以在 Azure OpenAI 文档 中找到支持的 API 版本列表。
实例化
现在我们可以实例化我们的模型对象并嵌入文本:索引和检索
嵌入模型通常用于检索增强生成 (RAG) 流程,既作为索引数据的一部分,也用于后续检索。有关更详细的说明,请参阅 学习 标签页下的 RAG 教程。 下面,了解如何使用我们上面初始化的embeddings 对象索引和检索数据。在此示例中,我们将使用演示版 MemoryVectorStore 索引和检索示例文档。
直接使用
在底层,向量存储和检索器实现调用embeddings.embedDocument(...) 和 embeddings.embedQuery(...) 来为 fromDocuments 和检索器的 invoke 操作中使用的文本创建嵌入。
您可以直接调用这些方法来获取嵌入以供您自己的用例使用。
嵌入单个文本
您可以使用embedQuery 嵌入用于搜索的查询。这会生成特定于查询的向量表示:
嵌入多个文本
您可以使用embedDocuments 嵌入多个文本以进行索引。此方法内部使用的实现可能(但不一定)与嵌入查询不同:
使用 Azure 托管标识
如果您使用 Azure 托管标识,可以像这样配置凭据:使用不同的域
如果您的实例托管在默认openai.azure.com 以外的域下,您需要使用备用的 AZURE_OPENAI_BASE_PATH 环境变量。
例如,以下是如何连接到域 https://westeurope.api.microsoft.com/openai/deployments/{DEPLOYMENT_NAME}:
自定义标头
您可以通过传递configuration 字段来指定自定义标头:
configuration 字段还接受官方 SDK 接受的其他 ClientOptions 参数。
注意: 特定标头 api-key 目前无法以这种方式覆盖,它将传递来自 azureOpenAIApiKey 的值。
从 Azure OpenAI SDK 迁移
如果您正在使用已弃用的 Azure OpenAI SDK 和@langchain/azure-openai 包,您可以按照以下步骤更新代码以使用新的 Azure 集成:
-
安装新的
@langchain/openai包并移除之前的@langchain/azure-openai包:npm -
更新您的导入以使用来自
@langchain/openai包的新AzureOpenAIEmbeddings类: -
更新您的代码以使用新的
AzureOpenAIEmbeddings类并传递所需的参数:请注意,构造函数现在需要azureOpenAIApiInstanceName参数而不是azureOpenAIEndpoint参数,并添加了azureOpenAIApiVersion参数来指定 API 版本。-
如果您使用的是 Azure 托管标识,现在需要在构造函数中使用
azureADTokenProvider参数而不是credentials,有关更多详细信息,请参阅 Azure 托管标识 部分。 -
如果您使用的是环境变量,现在必须设置
AZURE_OPENAI_API_INSTANCE_NAME环境变量而不是AZURE_OPENAI_API_ENDPOINT,并添加AZURE_OPENAI_API_VERSION环境变量来指定 API 版本。
-
如果您使用的是 Azure 托管标识,现在需要在构造函数中使用
API 参考
有关所有AzureOpenAIEmbeddings 功能和配置的详细文档,请前往 API 参考。
通过 MCP 将这些文档 连接到 Claude、VSCode 等以获取实时答案。

