Skip to main content
一个 LangGraph 应用程序由一个或多个图、一个配置文件 (langgraph.json)、一个指定依赖项的文件以及一个可选的 .env 文件(用于指定环境变量)组成。 本指南展示了一个应用程序的典型结构,并向您展示如何提供所需的配置以使用 LangSmith Deployment 部署应用程序。
LangSmith Deployment 是一个托管平台,用于部署和扩展 LangGraph 代理。它处理基础设施、扩展和操作问题,因此您可以直接从存储库部署有状态、长期运行的代理。请在 部署文档 中了解更多信息。

关键概念

要使用 LangSmith 进行部署,应提供以下信息:
  1. 一个 LangGraph 配置文件 (langgraph.json),用于指定应用程序要使用的依赖项、图和环境变量。
  2. 实现应用程序逻辑的
  3. 一个指定运行应用程序所需 依赖项 的文件。
  4. 应用程序运行所需的 环境变量

文件结构

以下是应用程序目录结构的示例:
my-app/
├── my_agent # 所有项目代码位于此处
│   ├── utils # 图的实用工具
│   │   ├── __init__.py
│   │   ├── tools.py # 图的工具
│   │   ├── nodes.py # 图的节点函数
│   │   └── state.py # 图的状态定义
│   ├── __init__.py
│   └── agent.py # 构建图的代码
├── .env # 环境变量
├── requirements.txt # 包依赖项
└── langgraph.json # LangGraph 配置文件
LangGraph 应用程序的目录结构可能因使用的编程语言和包管理器而异。

配置文件

langgraph.json 文件是一个 JSON 文件,用于指定部署 LangGraph 应用程序所需的依赖项、图、环境变量和其他设置。 有关 JSON 文件中所有支持键的详细信息,请参阅 LangGraph 配置文件参考
LangGraph CLI 默认使用当前目录中的配置文件 langgraph.json

示例

  • 依赖项涉及一个自定义本地包和 langchain_openai 包。
  • 从文件 ./your_package/your_file.py 加载一个图,变量为 variable
  • 环境变量从 .env 文件加载。
{
  "dependencies": ["langchain_openai", "./your_package"],
  "graphs": {
    "my_agent": "./your_package/your_file.py:agent"
  },
  "env": "./.env"
}

依赖项

LangGraph 应用程序可能依赖于其他 Python 包。 您通常需要指定以下信息以正确设置依赖项:
  1. 目录中指定依赖项的文件(例如 requirements.txtpyproject.tomlpackage.json)。
  2. LangGraph 配置文件 中的 dependencies 键,用于指定运行 LangGraph 应用程序所需的依赖项。
  3. 任何额外的二进制文件或系统库可以使用 LangGraph 配置文件 中的 dockerfile_lines 键指定。

使用 LangGraph 配置文件 中的 graphs 键来指定哪些图将在部署的 LangGraph 应用程序中可用。 您可以在配置文件中指定一个或多个图。每个图由一个名称(应唯一)和一个路径标识,该路径可以是:(1) 编译后的图或 (2) 定义图的函数。

环境变量

如果您在本地使用部署的 LangGraph 应用程序,可以在 LangGraph 配置文件env 键中配置环境变量。 对于生产部署,您通常需要在部署环境中配置环境变量。