当前位置: 首页 > news >正文

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

本文将带你从零搭建一个基于 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: 有不对的地方,欢迎留言)

http://www.rkmt.cn/news/81417.html

相关文章:

  • 净化车间制造厂家2025最新榜单出炉!无锡新源环保引领行业新标杆! - 深度智识库
  • 2025 年 12 月实验室整体解决方案实力推荐:涵盖实验室规划设计、实验室装修、实验台通风柜定制集成一站式服务,源头工厂专业可靠高效省心 - 深度智识库
  • 【2025权威发布】长轴液下泵|不锈钢液下泵|不锈钢化工泵|衬氟磁力泵|自吸磁力泵哪个厂家品质口碑好,知名企业品牌排行——亚梅泵业出众 - 品牌推荐大师1
  • 海外仓WMS系统选型:自研vsSaaS模式,企业该怎么选?
  • 2025年毛绒玩具除尘机工厂权威推荐榜单:毛绒玩具吹毛机/玩具行业封箱打包机/封箱打包机源头厂家精选 - 品牌推荐官
  • 2025年铁基催化剂生产厂家权威推荐榜单:沼气脱硫剂/高效脱硫剂/煤气脱硫催化剂源头厂家精选 - 品牌推荐官
  • 2025年真空皮带过滤机源头厂家推荐榜单:橡胶真空过滤机‌/水平真空过滤机‌/水平带式过滤机源头厂家精选 - 品牌推荐官
  • 完整教程:多智能体框架AgentScope 1.0 深度技术剖析:架构、场景、选型与实战指南
  • 洛谷 P3706
  • UniTask如何做到“零分配”
  • 2025年潮州凤凰单丛茶品牌口碑推荐榜单以及全面解析 - 讯息观点
  • 如何实现 vxe-tree 树组件拖拽节点后进行二次确认提示
  • SecureCRT SecureFX 9.7 for macOS, Linux, Windows - 跨平台的多协议终端仿真和文件传输
  • PostgreSQL 19:超高速聚合的全新突破
  • pycharm2025.3 12月最新 安装、授权、使用说明
  • GL980/GL2000/GL7000/USB蓝牙冷链温度记录仪选购指南:优质品牌、口碑厂家及供应商推荐 - 品牌推荐大师
  • 国标GB28181算法算力平台EasyGBS港口智能化监控解决方案
  • 2025年行业内知名的金属探测门品牌推荐,目前评价好的金属探测门推荐10年质保有保障 - 品牌推荐师
  • 2025年全自动一体化泵站工厂推荐榜单:玻璃钢一体化泵站‌/一体化消防泵站‌/一体化地埋式泵站源头工厂精选 - 品牌推荐官
  • 就医160 健康160 APP上如何用医保卡挂号支付
  • 2025年12月实验室规划设计公司实力推荐:涵盖实验台、通风柜、实验室装修及整体建设一站式服务,专业高效安全可靠 - 深度智识库
  • 2025年用户推荐的/质量好的纳米粒度分析仪厂家/信誉好的智能激光粒度分析仪生产厂家 - 品牌推荐大师1
  • 日本图技(GRAPHTEC)GL860A-HP记录仪2025代理供应商厂家推荐,厂家联系信息、电话 - 品牌推荐大师
  • 2025年靠谱的无菌隔离器品牌排行榜单/品牌对比/源头厂家推荐/价格对比 - 品牌推荐大师1
  • 国内专业水处理设备/全自动水处理设备/定制水处理设备/生产厂家品牌推荐,可提供定制服务 - 品牌推荐大师
  • 2025年农作物病虫害监测预警系统订制厂家推荐榜单:物联网虫情测报灯‌/病虫害监测系统‌/土壤墒情监测站源头厂家精选 - 品牌推荐官
  • 2025口碑好的智能防爆包装封口机供应商TOP5:安全与效能 - myqiye
  • 国产全自动纯化水设备|全自动超纯水设备:生产商、品牌及厂家推荐 - 品牌推荐大师
  • 沈阳天仁合一科技有限公司的优势在哪?其行业口碑怎样? - mypinpai
  • 信号与系统 于慧敏 抽样函数