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 等,以获取实时答案。

