当前位置: 首页 > 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.jsqmd.com/news/70870/

相关文章:

  • 净化车间制造厂家2025最新榜单出炉!无锡新源环保引领行业新标杆! - 深度智识库
  • 2025 年 12 月实验室整体解决方案实力推荐:涵盖实验室规划设计、实验室装修、实验台通风柜定制集成一站式服务,源头工厂专业可靠高效省心 - 深度智识库
  • 2025年洁净车间制造厂家综合实力榜:TOP5权威推荐与选购指南 - 深度智识库
  • Scoket编程快速入门(全面干货) - 指南
  • 2025年简约智能家居照明灯供应厂家有哪些特点? - 讯息观点
  • 海外仓WMS系统选型:自研vsSaaS模式,企业该怎么选?
  • 2025年管道离心泵哪家企业质量好/公司品质好/哪个厂家性能好/优质生产商制造商推荐/性价比高 - 品牌推荐大师1
  • 2025年优质护眼吸顶灯厂家推荐及极简风格设计解析 - 讯息观点
  • 【2025权威发布】长轴液下泵|不锈钢液下泵|不锈钢化工泵|衬氟磁力泵|自吸磁力泵哪个厂家品质口碑好,知名企业品牌排行——亚梅泵业出众 - 品牌推荐大师1
  • 2025年铁基催化剂生产厂家权威推荐榜单:沼气脱硫剂/高效脱硫剂/煤气脱硫催化剂源头厂家精选 - 品牌推荐官
  • 2025年毛绒玩具除尘机工厂权威推荐榜单:毛绒玩具吹毛机/玩具行业封箱打包机/封箱打包机源头厂家精选 - 品牌推荐官
  • HashMap的底层原理
  • 天猫超市卡回收主流平台推荐,这两家值得选 - 讯息观点
  • 2025年真空皮带过滤机源头厂家推荐榜单:橡胶真空过滤机‌/水平真空过滤机‌/水平带式过滤机源头厂家精选 - 品牌推荐官
  • 为你推荐:用户好评度高且评价优良的国产家用工业反渗透膜实力厂家推荐榜/生产企业公司 - 品牌推荐大师
  • 为什么销售目标越拆越细,执行力反而越差?
  • 2025年国内口碑好的8款农业无人机电池产品排行榜 - 讯息观点
  • 完整教程:多智能体框架AgentScope 1.0 深度技术剖析:架构、场景、选型与实战指南
  • 2025年大型冻干机源头厂家推荐榜单:冷冻式干燥机‌/果蔬冻干机设备‌/5平方真空冻干机源头厂家精选 - 品牌推荐官
  • GCDEX - GCD Extreme
  • 一次小脾气的发泄_2025年12月10日午餐
  • Nginx负载均衡(反向代理)——提升系统的吞吐率、请求性能、高容灾
  • 洛谷 P3706
  • 洛谷 P3706
  • 奖项
  • 创建抖音新号分享知识推广开源项目
  • 1-模型和算法
  • Nexpose 8.32.0 for Linux Windows - 漏洞扫描
  • 2025年潮州凤凰单丛茶品牌口碑推荐榜单以及全面解析 - 讯息观点
  • UniTask如何做到“零分配”