尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

使用 LangChain 搭建一个 AI Agent:从零到可运行 Demo

使用 LangChain 搭建一个 AI Agent:从零到可运行 Demo
📅 发布时间:2026/6/20 20:54:09

本文将带你从零搭建一个基于 LangChain + NestJS + Gemini 的 AI Agent Demo。

使用的是NestJS框架,不了解的可能需要先了解下。

大模型使用Gemini,Gemini有免费配额。

直接开整:

1. 建项目,导包

npm i -g @nestjs/cli
nest new langchain-agent-demo

导包

npm add @langchain/core @langchain/google-genai @langchain/agents zod 

2. 建模块

模块建立纯属个人习惯,大可按照自己的规范来。

image

3. 开搓

tools://tools 工具,给llm调用的 

import { z } from 'zod';
import { DynamicStructuredTool } from '@langchain/core/tools';// 新增
export const addTool = new DynamicStructuredTool({name: 'addItem',description: '新增一个项目',schema: z.object({name: z.string(),}),async func({ name }) {console.log('11执行新增:', name);return `已新增: ${name}`;},
});// 删除
export const deleteTool = new DynamicStructuredTool({name: 'deleteItem',description: '删除一个项目',schema: z.object({id: z.string(),}),async func({ id }) {console.log('执行删除:', id);return `已删除: ${id}`;},
});// 修改
export const updateTool = new DynamicStructuredTool({name: 'updateItem',description: '修改一个项目',schema: z.object({id: z.string(),name: z.string(),}),async func({ id, name }) {console.log('执行修改:', id, name);return `已修改 ID=${id}, 新名称=${name}`;},
});export const selectTool = new DynamicStructuredTool({name: 'selectItem',description: '查询项目,可以查询所有项目或者单个项目',schema: z.object({}),async func() {console.log('执行查询11');return `已执行查询所有:123`;},
});

service:

import { Injectable } from '@nestjs/common';
import { ChatPromptTemplate } from '@langchain/core/prompts';
import { ChatGoogleGenerativeAI } from '@langchain/google-genai';
import { addTool, deleteTool, selectTool, updateTool } from './tool/tool';@Injectable()
export class LangchainService {private readonly model: ChatGoogleGenerativeAI;constructor() {
   // ps: 访问gemini的api需要设置代理,不同llm 构建model的方法不同,也可使用langchain的createAgent(...)等方式,具体参考官方文档
this.model = new ChatGoogleGenerativeAI({model: 'gemini-2.5-flash-lite',apiKey: 'xxxxxxxx',//你的gemini api keytemperature: 0.7,});}/*** 简单 Demo:* 传入一个需求,Gemini对工具做出简单调用*/async chat(question: string) {// 1. Prompt 模版const prompt = ChatPromptTemplate.fromMessages([['system','你是一个智能助手,可以根据用户的要求调用工具,判断是否有数据增删改查要求调用工具',],['human', '{input}'],]);
  // 封工具
const modelWithTools = this.model.bindTools([addTool,deleteTool,updateTool,selectTool,]);const chain = prompt.pipe(modelWithTools); const aiMessage = await chain.invoke({ input: question });// 返回需要调用的工具,可以有多个console.log('工具调用信息:', aiMessage?.tool_calls);const results = [];if (aiMessage?.tool_calls?.length > 0) {for (const toolCall of aiMessage.tool_calls) {// 调用工具const toolMap = {addItem: addTool,deleteItem: deleteTool,updateItem: updateTool,selectItem: selectTool,};const tool = toolMap[toolCall.name];const result = await tool.func(toolCall.args);console.log('工具执行结果:', result);results.push(result);}}return results;} }

controller:

import { Body, Controller, Post } from '@nestjs/common';
import { LangchainService } from './langchain.service';


  class ChatDto {
    message: string;
  }
 
@Controller('langchain')
export class LangchainController {constructor(private readonly langchainService: LangchainService) {}@Post('chat')async chat(@Body() body: ChatDto) {const { message } = body;const answer = await this.langchainService.chat(message);return {question: message,answer,};}
}

4. 启动->运行 ->调用 -> ok

5.常见错误与排查建议

  1. fetch failed / timeout / 403:通常是模型 API 地址、代理、或 key 权限问题。

  2. 工具无法被调用:检查工具描述是否清晰。LLM 必须理解:工具用途、什么场景应该触发。(切记)

  3. 返回空白或不响应:Gemini 免费版可能存在限额。

(ps: 有不对的地方,欢迎留言)

相关新闻

  • 净化车间制造厂家2025最新榜单出炉!无锡新源环保引领行业新标杆! - 深度智识库
  • 2025 年 12 月实验室整体解决方案实力推荐:涵盖实验室规划设计、实验室装修、实验台通风柜定制集成一站式服务,源头工厂专业可靠高效省心 - 深度智识库
  • 【2025权威发布】长轴液下泵|不锈钢液下泵|不锈钢化工泵|衬氟磁力泵|自吸磁力泵哪个厂家品质口碑好,知名企业品牌排行——亚梅泵业出众 - 品牌推荐大师1

最新新闻

  • 嵌入式Linux开发:CodeWarrior IDE目标设置与GNU工具链配置详解
  • 如何高效管理京东任务:终极自动化脚本完全指南
  • 如何用Ice拯救你的Mac菜单栏?3步打造极致整洁的工作空间
  • 盘点抖店主流上货工具:抖掌柜核心功能全解,商家高频疑问一次性解答(2026最新) - 抖掌柜
  • LPC213x I2C驱动开发:寄存器解析、状态机实战与调试指南
  • 智己LS6和问界M7怎么选?2026款值得买的深度对比与理性选购建议 - 外贸老黄

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号