本指南向您展示如何将应用程序部署到带有控制平面混合自托管实例。使用控制平面,您在本地构建 Docker 镜像,将它们推送到 Kubernetes 集群可以访问的注册表,并使用 LangSmith UI 部署它们。
本指南用于部署应用程序,而不是设置基础设施。在使用本指南之前,您必须已完成基础设施设置:如果您尚未设置基础设施,请从平台设置部分开始。

概述

部署到带有控制平面的混合或自托管 LangSmith 实例的应用程序使用 Docker 镜像。在本指南中,应用程序部署工作流程如下:
  1. 使用 langgraph devStudio 在本地测试您的应用程序。
  2. 使用 langgraph build 命令构建 Docker 镜像。
  3. 将镜像推送到您的基础设施可以访问的容器注册表。
  4. 通过指定镜像 URL 从控制平面 UI 进行部署。

前提条件

在完成本指南之前,您需要以下内容:
  • 完成基础设施设置以使您的数据平面能够接收应用程序部署:
    • 混合设置:在连接到 LangChain 的托管控制平面的 Kubernetes 集群中安装数据平面组件(监听器、操作器、CRD)。
    • 启用 LangSmith Deployment:在您的自托管 LangSmith 实例上启用 LangSmith Deployment。
  • 访问已启用 LangSmith Deployment 的 LangSmith UI
  • Kubernetes 集群可以访问的容器注册表。

步骤 1. 本地测试

在部署之前,请在本地测试您的应用程序。您可以使用 LangGraph CLI 在开发模式下运行智能体服务器:
langgraph dev
有关完整的本地测试指南,请参阅本地服务器快速入门

步骤 2. 构建 Docker 镜像

使用 langgraph build 命令构建应用程序的 Docker 镜像:
langgraph build -t my-image
构建命令选项包括:
选项默认值描述
-t, --tag TEXT必需Docker 镜像的标签
--platform TEXT要构建的目标平台(例如,linux/amd64,linux/arm64
--pull / --no-pull--pull使用最新的远程 Docker 镜像构建
-c, --config FILElanggraph.json配置文件的路径
带有平台规范的示例:
langgraph build --platform linux/amd64 -t my-image:v1.0.0
有关完整详细信息,请参阅 CLI 参考

步骤 3. 推送到容器注册表

将您的镜像推送到 Kubernetes 集群可以访问的容器注册表。具体命令取决于您的注册表提供商。
使用版本信息标记您的镜像(例如,my-registry.com/my-app:v1.0.0)以便更容易回滚。

步骤 4. 使用控制平面 UI 部署

控制平面 UI 允许您创建和管理部署、查看日志和指标以及更新配置。要在 LangSmith UI 中创建新部署:
  1. 在左侧导航面板中,选择 Deployments
  2. 在右上角,选择 + New Deployment
  3. 在部署配置面板中,提供:
    • Image URL:您在步骤 3 中推送的完整镜像 URL。
    • Listener/Compute ID:选择为您的基础设施配置的监听器。
    • Namespace:要部署到的 Kubernetes 命名空间。
    • Environment variables:任何所需的配置(API 密钥等)。
    • 根据需要的其他部署设置。
  4. 选择 Submit
控制平面将与您的数据平面监听器协调以部署您的应用程序。 创建部署后,基础设施将异步配置。部署可能需要几分钟时间,初始部署由于数据库创建而需要更长时间。 从控制平面 UI,您可以查看构建日志、服务器日志和部署指标,包括 CPU/内存使用情况、副本和 API 性能。有关更多详细信息,请参阅控制平面监控文档
为每个部署自动创建与部署同名的 LangSmith 可观测性跟踪项目。跟踪环境变量由控制平面自动设置。

更新部署

要部署应用程序的新版本,请创建新修订版 从 LangSmith UI 开始:
  1. 在左侧导航面板中,选择 Deployments
  2. 选择现有部署。
  3. 在 Deployment 视图中,在右上角选择 + New Revision
  4. 更新配置:
    • Image URL 更新为您的新镜像版本。
    • 如果需要,更新环境变量。
    • 根据需要调整其他设置。
  5. 选择 Submit

后续步骤


Connect these docs programmatically to Claude, VSCode, and more via MCP for real-time answers.