[{"data":1,"prerenderedAt":3025},["ShallowReactive",2],{"search-docs":3,"doc-\u002Fai\u002Fagent\u002Fframeworks":886},[4,8,12,16,20,24,28,32,36,40,44,48,52,56,60,64,68,72,76,80,84,88,92,96,100,104,108,112,116,120,124,128,132,136,140,144,148,152,156,159,162,165,169,172,175,178,182,186,190,194,198,202,206,210,214,218,222,226,230,234,238,242,246,250,254,258,262,266,269,273,277,281,285,288,291,294,298,301,304,307,310,313,316,319,322,325,329,332,336,340,344,348,352,356,359,362,365,368,371,374,377,380,383,386,389,393,396,399,402,405,408,411,414,417,420,424,428,432,435,438,442,446,450,454,458,462,466,470,474,477,480,483,487,491,494,497,500,504,507,511,515,518,521,524,527,530,533,536,539,542,545,548,551,554,557,560,563,566,569,572,575,579,583,587,591,595,599,603,606,610,614,617,620,623,626,629,633,637,640,643,646,649,652,655,658,661,664,667,670,673,676,679,682,685,688,691,694,697,700,703,706,709,712,716,720,724,728,732,736,740,744,748,752,756,760,764,768,772,775,779,783,787,790,793,796,799,802,805,808,811,814,818,822,825,829,832,835,838,841,844,848,851,854,858,862,865,869,873,876,879,882],{"path":5,"title":6,"description":7},"\u002Fabout\u002Fauthor","作者相关","只想纯粹的做一个程序员...",{"path":9,"title":10,"description":11},"\u002Fabout\u002Fjourney","心路历程","",{"path":13,"title":14,"description":15},"\u002Fai\u002Fagent\u002Fframeworks","Agent 框架","主流 Agent 框架：LangChain、LlamaIndex、AutoGen、CrewAI",{"path":17,"title":18,"description":19},"\u002Fai\u002Fagent\u002Fhooks","Agent Hooks 与自动化","Claude Agent 的 Hooks 生命周期、事件类型、典型自动化场景",{"path":21,"title":22,"description":23},"\u002Fai\u002Fagent\u002Fintroduction","AI Agent 概述","AI Agent 核心概念：感知、规划、执行、记忆",{"path":25,"title":26,"description":27},"\u002Fai\u002Fagent\u002Fpractice","Agent 实战","AI Agent 实战：构建自主任务执行系统",{"path":29,"title":30,"description":31},"\u002Fai\u002Fagent\u002Fsdk","Claude Agent SDK 开发","使用 Claude Agent SDK 构建自定义 AI Agent：架构、API、生命周期",{"path":33,"title":34,"description":35},"\u002Fai\u002Fagent\u002Fsubagents","Subagents 子代理","用 Subagents 分解复杂任务、并发执行、隔离上下文",{"path":37,"title":38,"description":39},"\u002Fai\u002Fagent\u002Ftool-use","工具调用","AI Agent 工具调用：Function Calling、Tool Use 原理与实践",{"path":41,"title":42,"description":43},"\u002Fai\u002Ffundamentals\u002Fdeep-learning","深度学习入门","深度学习基础知识：前向传播、反向传播、损失函数、优化器",{"path":45,"title":46,"description":47},"\u002Fai\u002Ffundamentals\u002Fml-basics","机器学习基础","机器学习核心概念：监督学习、无监督学习、强化学习",{"path":49,"title":50,"description":51},"\u002Fai\u002Ffundamentals\u002Fneural-networks","神经网络原理","神经网络架构：CNN、RNN、注意力机制",{"path":53,"title":54,"description":55},"\u002Fai\u002Fgetting-started","AI 学习路线","AI 技术学习路线图，从基础到实战的完整指南",{"path":57,"title":58,"description":59},"\u002Fai\u002Fllm\u002Ffine-tuning","模型微调","大模型微调技术：LoRA、QLoRA、全量微调、RLHF",{"path":61,"title":62,"description":63},"\u002Fai\u002Fllm\u002Fintroduction","大模型概述","大语言模型发展历程、核心能力与主流模型对比",{"path":65,"title":66,"description":67},"\u002Fai\u002Fllm\u002Flocal-deploy","本地部署","大模型本地部署：Ollama、vLLM、llama.cpp",{"path":69,"title":70,"description":71},"\u002Fai\u002Fllm\u002Ftransformer","Transformer 架构","Transformer 架构详解：自注意力机制、位置编码、多头注意力",{"path":73,"title":74,"description":75},"\u002Fai\u002Fmcp\u002Fclient","MCP Client 开发","MCP Client 开发指南：连接、调用、集成",{"path":77,"title":78,"description":79},"\u002Fai\u002Fmcp\u002Fdebugging","MCP 调试与排错","MCP Server 开发与集成过程中的常见问题、日志分析、诊断工具",{"path":81,"title":82,"description":83},"\u002Fai\u002Fmcp\u002Fintroduction","MCP 概述","Model Context Protocol 协议概述：架构、核心概念、应用场景",{"path":85,"title":86,"description":87},"\u002Fai\u002Fmcp\u002Fserver","MCP Server 开发","MCP Server 开发指南：资源、工具、提示词的实现",{"path":89,"title":90,"description":91},"\u002Fai\u002Fmcp\u002Ftools","MCP Tools 深入","深入理解 MCP Tools：与 Resources\u002FPrompts 的差异、Schema 设计、Annotations 与权限控制",{"path":93,"title":94,"description":95},"\u002Fai\u002Fprompt\u002Fadvanced","高级 Prompt 模式","高级 Prompt 设计模式：Tree-of-Thought、自我反思、多轮对话策略",{"path":97,"title":98,"description":99},"\u002Fai\u002Fprompt\u002Fbasics","Prompt 基础","Prompt Engineering 入门：基本概念、角色设定、输出格式控制",{"path":101,"title":102,"description":103},"\u002Fai\u002Fprompt\u002Ftechniques","提示词技巧","常用提示词技巧：Few-shot、Chain-of-Thought、ReAct",{"path":105,"title":106,"description":107},"\u002Fai\u002Frag\u002Fembedding","文本嵌入","文本嵌入模型：Embedding 原理、模型选择、相似度计算",{"path":109,"title":110,"description":111},"\u002Fai\u002Frag\u002Fintroduction","RAG 概述","检索增强生成（RAG）架构原理、优势与应用场景",{"path":113,"title":114,"description":115},"\u002Fai\u002Frag\u002Fpractice","RAG 实战","RAG 应用实战：文档问答系统、知识库搭建",{"path":117,"title":118,"description":119},"\u002Fai\u002Frag\u002Fvector-database","向量数据库","主流向量数据库对比：Milvus、Pinecone、Chroma、Weaviate",{"path":121,"title":122,"description":123},"\u002Fai\u002Fskills\u002Fbest-practices","Skill 最佳实践","编写高质量 Skill 的设计原则、常见陷阱与优化技巧",{"path":125,"title":126,"description":127},"\u002Fai\u002Fskills\u002Fcreating","创建自定义 Skill","从零编写一个可被 Agent 自动发现和调用的 Skill",{"path":129,"title":130,"description":131},"\u002Fai\u002Fskills\u002Fintroduction","Agent Skills 概述","Claude Agent Skills 概念、工作原理、与 Tools\u002FMCP 的区别",{"path":133,"title":134,"description":135},"\u002Fgolang\u002Fadvanced\u002Fconcurrency","Go - 并发深入","深入理解 Go 并发编程的核心机制。",{"path":137,"title":138,"description":139},"\u002Fgolang\u002Fadvanced\u002Fgc","Go - 垃圾回收","理解 Go 的垃圾回收机制，掌握 GC 调优方法。",{"path":141,"title":142,"description":143},"\u002Fgolang\u002Fadvanced\u002Fgmp","Go - GMP 调度模型","GMP 是 Go 运行时调度器的核心模型，理解它对于编写高性能 Go 程序至关重要。",{"path":145,"title":146,"description":147},"\u002Fgolang\u002Fadvanced\u002Fgo-concurrency","Go - 并发编程","Go 的并发是其核心特性之一，通过 Goroutine 和 Channel 实现。",{"path":149,"title":150,"description":151},"\u002Fgolang\u002Fadvanced\u002Fmemory","Go - 内存模型","理解 Go 的内存分配机制和内存模型。",{"path":153,"title":154,"description":155},"\u002Fgolang\u002Fadvanced\u002Fprofiling","Go - 性能分析","掌握 Go 的性能分析工具：pprof、trace、benchmark。",{"path":157,"title":158,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-basic","Go - 基础语法",{"path":160,"title":161,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-composite","Go - 复合类型",{"path":163,"title":164,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-control","Go - 流程控制",{"path":166,"title":167,"description":168},"\u002Fgolang\u002Fcore\u002Fgo-error","Go - 错误处理","Go 使用显式的错误返回值来处理错误，而不是异常机制。",{"path":170,"title":171,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-function","Go - 函数",{"path":173,"title":174,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-install","Go - 环境搭建",{"path":176,"title":177,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-interface","Go - 接口",{"path":179,"title":180,"description":181},"\u002Fgolang\u002Fcore\u002Fgo-module","Go - 包管理","Go Modules 是 Go 1.11 引入的官方依赖管理方案，Go 1.16 后成为默认模式。",{"path":183,"title":184,"description":185},"\u002Fgolang\u002Fdistributed\u002Fgrpc","Go - gRPC","gRPC 是 Google 开发的高性能 RPC 框架，使用 Protocol Buffers 作为序列化协议。",{"path":187,"title":188,"description":189},"\u002Fgolang\u002Fdistributed\u002Fmicroservice","Go - 微服务","微服务架构的核心组件：服务发现、负载均衡、熔断降级。",{"path":191,"title":192,"description":193},"\u002Fgolang\u002Fdistributed\u002Fmq","Go - 消息队列","使用 Go 操作 Kafka 和 RabbitMQ。",{"path":195,"title":196,"description":197},"\u002Fgolang\u002Fdistributed\u002Fredis","Go - Redis","使用 go-redis 操作 Redis，实现缓存、分布式锁等功能。",{"path":199,"title":200,"description":201},"\u002Fgolang\u002Fengineering\u002Fconfig","Go - 配置管理","使用 viper 进行配置管理，支持多种配置格式和配置中心。",{"path":203,"title":204,"description":205},"\u002Fgolang\u002Fengineering\u002Fdocker","Go - Docker 部署","使用 Docker 容器化部署 Go 应用。",{"path":207,"title":208,"description":209},"\u002Fgolang\u002Fengineering\u002Fkubernetes","Go - Kubernetes 部署","在 Kubernetes 上部署和管理 Go 应用。",{"path":211,"title":212,"description":213},"\u002Fgolang\u002Fengineering\u002Flogging","Go - 日志系统","使用 zap 和 logrus 构建高性能结构化日志系统。",{"path":215,"title":216,"description":217},"\u002Fgolang\u002Fengineering\u002Ftesting","Go - 单元测试","Go 内置了强大的测试框架，掌握测试是编写高质量代码的基础。",{"path":219,"title":220,"description":221},"\u002Fgolang\u002Fstdlib\u002Fbufio","bufio","在 Go 语言中，bufio 包提供了带缓冲的 I\u002FO 操作，能够提高读写性能。以下是一些常用的 bufio 包 API 及其详细说明：",{"path":223,"title":224,"description":225},"\u002Fgolang\u002Fstdlib\u002Fcontainer","container","在Go语言标准库中，container 包提供了几种常用的数据结构实现，这些数据结构对于高效地管理和操作数据非常有用。以下是 container 包中主要的数据结构：",{"path":227,"title":228,"description":229},"\u002Fgolang\u002Fstdlib\u002Fcrypto","crypto","在 Go 语言中，crypto 包提供了一组用于加密和解密的功能。以下是一些常用的 crypto 包及其子包的 API 及其详细说明：",{"path":231,"title":232,"description":233},"\u002Fgolang\u002Fstdlib\u002Fencoding-csv","encoding\u002Fcsv","在 Go 语言中，encoding\u002Fcsv 包提供了对 CSV（逗号分隔值）文件进行读写的功能。以下是一些常用的 encoding\u002Fcsv 包的 API 及其详细说明：",{"path":235,"title":236,"description":237},"\u002Fgolang\u002Fstdlib\u002Fencoding-json","encoding\u002Fjson","在 Go 语言中，encoding\u002Fjson 包提供了对 JSON 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fjson 包的 API 及其详细说明：",{"path":239,"title":240,"description":241},"\u002Fgolang\u002Fstdlib\u002Fencoding-xml","encoding\u002Fxml","在 Go 语言中，encoding\u002Fxml 包提供了对 XML 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fxml 包的 API 及其详细说明：",{"path":243,"title":244,"description":245},"\u002Fgolang\u002Fstdlib\u002Fflag","flag","在Go语言中，flag 包是用于处理命令行参数的标准库，它提供了一种简单而直接的方式来解析和使用命令行参数。下面是关于 flag 包的一些基本介绍和常用功能：",{"path":247,"title":248,"description":249},"\u002Fgolang\u002Fstdlib\u002Ffmt","fmt","在 Go 语言的标准库中，fmt 包是非常重要的，它提供了处理格式化输入和输出的基本工具。以下是一些 fmt 包内常用的API：",{"path":251,"title":252,"description":253},"\u002Fgolang\u002Fstdlib\u002Fhttp","net\u002Fhttp","在 Go 语言中，net\u002Fhttp 包提供了用于构建 HTTP 客户端和服务器的强大工具。以下是一些常用的 net\u002Fhttp 包的 API 及其详细说明：",{"path":255,"title":256,"description":257},"\u002Fgolang\u002Fstdlib\u002Fio","io","在 Go 语言中，io 包提供了基本的输入输出功能。以下是一些常用的 io 包的 API 及其详细说明：",{"path":259,"title":260,"description":261},"\u002Fgolang\u002Fstdlib\u002Flog","log","在 Go 语言中，log 包提供了简单的日志记录功能。以下是一些常用的 log 包的 API 及其详细说明：",{"path":263,"title":264,"description":265},"\u002Fgolang\u002Fstdlib\u002Fmath","math","在 Go 语言中，math 包提供了基本的数学函数和常量。以下是一些常用的 math 包的 API 及其详细说明：",{"path":267,"title":268,"description":11},"\u002Fgolang\u002Fstdlib\u002Fnet","net",{"path":270,"title":271,"description":272},"\u002Fgolang\u002Fstdlib\u002Fos","os","在Go语言中，os 包是一个非常重要且常用的标准库，它提供了与操作系统交互的功能，包括文件操作、环境变量管理、进程管理等。下面是一些 os 包中常用的功能和API：",{"path":274,"title":275,"description":276},"\u002Fgolang\u002Fstdlib\u002Fsort","order","在 Go 语言中，sort 包提供了对切片和用户定义的集合进行排序的函数。它实现了常见的排序算法，如快速排序（Quicksort）和堆排序（Heapsort），并且为自定义集合提供了接口，使得用户可以根据特定的需求进行排序。",{"path":278,"title":279,"description":280},"\u002Fgolang\u002Fstdlib\u002Fstrconv","strconv","在 Go 语言中，strconv 包提供了字符串和基本数据类型之间的转换函数，例如将整数转换为字符串、字符串转换为整数，以及其他类型之间的转换。这些功能非常有用，特别是在处理用户输入或从外部数据源读取数据时。",{"path":282,"title":283,"description":284},"\u002Fgolang\u002Fstdlib\u002Ftime","time","在 Go 语言中，time 包提供了处理时间和日期的功能。以下是一些常用的 time 包的 API 及其详细说明：",{"path":286,"title":287,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ferror","Gin - 错误处理",{"path":289,"title":290,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ffile","Gin - 文件处理",{"path":292,"title":293,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fmiddleware","Gin - 中间件",{"path":295,"title":296,"description":297},"\u002Fgolang\u002Fweb\u002Fgin\u002Fquickstart","Gin - 快速开始","Gin 是目前最流行的 Go Web 框架，以高性能和简洁 API 著称。",{"path":299,"title":300,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frequest","Gin - 请求处理",{"path":302,"title":303,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fresponse","Gin - 响应处理",{"path":305,"title":306,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frouter","Gin - 路由",{"path":308,"title":309,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fvalidation","Gin - 参数校验",{"path":311,"title":312,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fassociation","GORM - 关联关系",{"path":314,"title":315,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fcrud","GORM - CRUD 操作",{"path":317,"title":318,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fmodel","GORM - 模型定义",{"path":320,"title":321,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fperformance","GORM - 日志与性能",{"path":323,"title":324,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquery","GORM - 高级查询",{"path":326,"title":327,"description":328},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquickstart","GORM - 快速开始","GORM 是 Go 语言最流行的 ORM 库，功能强大，使用简单。",{"path":330,"title":331,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Ftransaction","GORM - 事务与 Hook",{"path":333,"title":334,"description":335},"\u002Finterview\u002Fbasic","计算机基础面经","本章节汇总了面试中常见的通用技术概念，不局限于特定语言或数据库，是考察技术内功的关键考点。",{"path":337,"title":338,"description":339},"\u002Finterview\u002Fgolang","Golang 面试题","Go 语言面试高频考点，覆盖基础语法、数据结构、并发编程、内存管理、GC、调度器等核心知识。",{"path":341,"title":342,"description":343},"\u002Finterview\u002Fk8s","Kubernetes 面试题","Kubernetes（K8s）面试高频考点，覆盖架构原理、核心资源、网络存储、调度策略、运维监控等核心知识。",{"path":345,"title":346,"description":347},"\u002Finterview\u002Fmysql","MySQL 面试题","MySQL 数据库面试高频考点，覆盖索引、事务、锁、优化、主从复制等核心知识。",{"path":349,"title":350,"description":351},"\u002Finterview\u002Fredis","Redis 面试题","Redis 面试高频考点，覆盖数据结构、持久化、集群、缓存一致性、性能优化等核心知识。",{"path":353,"title":354,"description":355},"\u002Finterview\u002Frocketmq","RocketMQ 面试题","RocketMQ 面试高频考点，覆盖消息模型、可靠性、顺序消息、事务消息、存储与高可用等核心知识。",{"path":357,"title":358,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-arraylist","List - ArrayList 源码解析",{"path":360,"title":361,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-linkedlist","List - LinkedList 源码解析",{"path":363,"title":364,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-stack","List - Satck源码解析",{"path":366,"title":367,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-vectore","List - Vector 源码解析",{"path":369,"title":370,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-hashmap","Map - HashMap 源码解析",{"path":372,"title":373,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-linkedhashmap","Map - LinkedHashMap 源码解析",{"path":375,"title":376,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-treemap","Map - TreeMap 源码解析",{"path":378,"title":379,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-deque","Queue - Deque 接口解析",{"path":381,"title":382,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-queue","Queue - Queue 接口解析",{"path":384,"title":385,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-hashset","Set - HashSet源码解析",{"path":387,"title":388,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-linkedhashset","Set - LinkedHashSet 源码解析",{"path":390,"title":391,"description":392},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-treeset","Set - TreeSet源码解析","TreeSet 是一个 Set 集合接口的实现类，与 HashSet 类似，其底层也是通过维护了一个 TreeMap 对象来封装了一些实现方法，故本篇不再对 TreeSet 的底层原理进行详细说明，仅对常用 API 做简单介绍，如需了解 TreeMap 的底层实现原理，请移步 Map - HashMap 源码解析",{"path":394,"title":395,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fannotation","Java核心 - 注解",{"path":397,"title":398,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fbasic-grammar","Java核心 - 基础语法",{"path":400,"title":401,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fclass-and-object","Java核心 - 面向对象",{"path":403,"title":404,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fcommon-classes","Java核心 - 常用类",{"path":406,"title":407,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fexception","Java核心 - 异常处理",{"path":409,"title":410,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fgenerics","Java核心 - 泛型",{"path":412,"title":413,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fjdk-env-path","Java核心 - 环境搭建",{"path":415,"title":416,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Freflection","Java核心 - 反射",{"path":418,"title":419,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fstring","Java核心 - String 字符串",{"path":421,"title":422,"description":423},"\u002Fother\u002Fjava\u002Fio\u002Fbuffer-stream","Java IO - 缓冲流","缓冲流是对基本流的包装，通过内置缓冲区减少系统调用次数，大幅提升读写效率。",{"path":425,"title":426,"description":427},"\u002Fother\u002Fjava\u002Fio\u002Fbyte-stream","Java IO - 字节流","字节流是 Java IO 中最基本的流类型，以字节（byte）为单位进行数据读写，可以处理任意类型的文件。",{"path":429,"title":430,"description":431},"\u002Fother\u002Fjava\u002Fio\u002Fchar-stream","Java IO - 字符流","字符流以字符为单位进行读写，专门用于处理文本文件。相比字节流，字符流能够正确处理字符编码，避免中文乱码问题。",{"path":433,"title":434,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Ffile","Java IO - File 类",{"path":436,"title":437,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Fio-stream-system","Java IO - IO流概述",{"path":439,"title":440,"description":441},"\u002Fother\u002Fjava\u002Fio\u002Fnio","Java IO - NIO","NIO（New IO）是 JDK 1.4 引入的新 IO 模型，提供了更高效的 IO 操作方式，支持非阻塞 IO 和多路复用。",{"path":443,"title":444,"description":445},"\u002Fother\u002Fjava\u002Fjvm\u002Fclass-loading","类加载机制","类加载机制是 JVM 将 .class 文件加载到内存，并对数据进行校验、转换解析和初始化，最终形成可被 JVM 直接使用的 Java 类型的过程。",{"path":447,"title":448,"description":449},"\u002Fother\u002Fjava\u002Fjvm\u002Fgarbage-collection","垃圾回收","垃圾回收（Garbage Collection，GC）是 JVM 自动管理内存的机制，负责回收不再使用的对象所占用的内存。",{"path":451,"title":452,"description":453},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-memory","JVM 内存结构","JVM 在执行 Java 程序时，会把它管理的内存划分为若干个不同的数据区域。这些区域有各自的用途、创建和销毁时间。",{"path":455,"title":456,"description":457},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-tuning","JVM 调优","JVM 调优是优化 Java 应用性能的重要手段，主要包括参数配置、性能监控和问题排查。",{"path":459,"title":460,"description":461},"\u002Fother\u002Fjava\u002Fthread\u002Fatomic","原子类","Java 原子类（Atomic Classes）提供了一种无锁的线程安全方式，基于 CAS（Compare-And-Swap）操作实现。",{"path":463,"title":464,"description":465},"\u002Fother\u002Fjava\u002Fthread\u002Fcompletable-future","CompletableFuture","CompletableFuture 是 JDK 8 引入的异步编程工具，实现了 Future 和 CompletionStage 接口，支持函数式编程和链式调用。",{"path":467,"title":468,"description":469},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-collections","并发集合","Java 并发包提供了多种线程安全的集合类，用于替代传统的同步集合（如 Collections.synchronizedList）。",{"path":471,"title":472,"description":473},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-utils","并发工具类","Java 并发包提供了多种实用的并发工具类，用于控制线程之间的协调与同步。",{"path":475,"title":476,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fsynchronized-lock","同步机制",{"path":478,"title":479,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-basic","线程基础",{"path":481,"title":482,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-pool","线程池",{"path":484,"title":485,"description":486},"\u002Fother\u002Fspring-series\u002Fspring\u002Fannotations-beans","Spring - 基于注解管理Bean","从 Java 5 开始，Java 增加了对注解（Annotation）的支持，它是代码中的一种特殊标记，可以在编译、类加载和运行时被读取，执行相应的处理。开发人员可以通过注解在不改变原有代码和逻辑的情况下，在源代码中嵌入补充信息。",{"path":488,"title":489,"description":490},"\u002Fother\u002Fspring-series\u002Fspring\u002Fimplement-ioc","Spring - 原理手写IoC","Spring 框架的 IOC 是基于 Java 反射机制实现的，在学习手写 IoC 之前，你需要具备一定的 Java 反射相关的知识，参考本站内的 Java 教程。",{"path":492,"title":493,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fintroduction-case","Spring - 入门案例",{"path":495,"title":496,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aop","Spring - 面向切面AOP",{"path":498,"title":499,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aot","Spring - AOT提前编译",{"path":501,"title":502,"description":503},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-data-validation","Spring - 数据校验","在开发中，我们经常遇到参数校验的需求，比如用户注册的时候，要校验用户名不能为空、用户名长度不超过20个字符、手机号是合法的手机号格式等等。如果使用普通方式，我们会把校验的代码和真正的业务处理逻辑耦合在一起，而且如果未来要新增一种校验逻辑也需要在修改多个地方。而spring validation允许通过注解的方式来定义对象校验规则，把校验和业务逻辑分离开，让代码编写更加方便。Spring Validation其实就是对Hibernate Validator进一步的封装，方便在Spring中使用。",{"path":505,"title":506,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-i18n","Spring - 国际化i18n",{"path":508,"title":509,"description":510},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-ioc","Spring - IOC容器","IoC 是 Inversion of Control 的简写，译为“控制反转”，它不是一门技术，而是一种设计思想，是一个重要的面向对象编程法则，能够指导我们如何设计出松耦合、更优良的程序。",{"path":512,"title":513,"description":514},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-junit","Spring - 单元测试JUnit","在之前的测试方法中，几乎都能看到以下的两行代码：",{"path":516,"title":517,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-resources","Spring - 资源操作",{"path":519,"title":520,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-summarize","Spring - Spring概述",{"path":522,"title":523,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-transaction","Spring - 事务",{"path":525,"title":526,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fxml-beans","Spring - 基于XML管理Bean",{"path":528,"title":529,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-config","SpringBoot - 配置详解",{"path":531,"title":532,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-data","SpringBoot - 数据访问",{"path":534,"title":535,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-quickstart","SpringBoot - 快速入门",{"path":537,"title":538,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-web","SpringBoot - Web 开发",{"path":540,"title":541,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-config","SpringCloud - 配置中心",{"path":543,"title":544,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-discovery","SpringCloud - 服务注册与发现",{"path":546,"title":547,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-feign","SpringCloud - 服务调用",{"path":549,"title":550,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-gateway","SpringCloud - 服务网关",{"path":552,"title":553,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-introduction","SpringCloud - 微服务概述",{"path":555,"title":556,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-sentinel","SpringCloud - 服务保护",{"path":558,"title":559,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-databind","SpringMVC - 数据绑定与转换",{"path":561,"title":562,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-exception","SpringMVC - 异常处理",{"path":564,"title":565,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-interceptor","SpringMVC - 拦截器",{"path":567,"title":568,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-introduction","SpringMVC - 简介与环境搭建",{"path":570,"title":571,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-request","SpringMVC - 请求处理",{"path":573,"title":574,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-response","SpringMVC - 响应处理",{"path":576,"title":577,"description":578},"\u002Fproject\u002Frocket-leaf\u002Farchitecture","项目架构","Rocket-Leaf 的目录结构、模块划分、数据流向，以及各层之间的依赖关系。",{"path":580,"title":581,"description":582},"\u002Fproject\u002Frocket-leaf\u002Fbackend-layers","后端分层设计","Rocket-Leaf 的 model \u002F rocketmq \u002F service 三层结构，以及服务之间的依赖关系与设计取舍。",{"path":584,"title":585,"description":586},"\u002Fproject\u002Frocket-leaf\u002Fclient-manager","RocketMQ 客户端管理器","AdminClientManager 的多客户端池、默认连接懒加载、自动重连重试的设计与实现。",{"path":588,"title":589,"description":590},"\u002Fproject\u002Frocket-leaf\u002Fencryption","连接信息加密存储","AES-256-GCM + SHA-256 字段级派生密钥的实现，以及如何在不破坏兼容性的前提下为历史明文数据做透明迁移。",{"path":592,"title":593,"description":594},"\u002Fproject\u002Frocket-leaf\u002Ffrontend","前端结构与类型绑定","React + Vite 目录组织、自动生成的 Wails 绑定、api 薄封装与自定义 hooks 的职责划分。",{"path":596,"title":597,"description":598},"\u002Fproject\u002Frocket-leaf","项目简介","Rocket-Leaf 是一款基于 Wails v3 构建的跨平台 RocketMQ 桌面管理客户端，Go 后端 + React 前端。本文档系列拆解它的架构与关键实现。",{"path":600,"title":601,"description":602},"\u002Fproject\u002Frocket-leaf\u002Fwails-v3","Wails v3 入门","Wails v3 的核心概念、Service 绑定机制，以及 Rocket-Leaf 是如何用它把 Go 后端和 React 前端打通的。",{"path":604,"title":605,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-basic","Docker - 入门基础",{"path":607,"title":608,"description":609},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-compose","Docker - Compose","在部署应用时，常常使用到不止一个容器，那么在部署容器的时候就需要一个一个进行部署，这样的部署过程也相对来说比较繁琐复杂，也容易出问题，那么有没有一种更为简单的方法呢？",{"path":611,"title":612,"description":613},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-container-connection","Docker - 容器互联","在上一个章节中我们学习了 Docker 容器的端口映射，可以将 Docker 容器和本地以及网络中的端口进行连接起来。",{"path":615,"title":616,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-dockerfile","Docker - Dockerfile",{"path":618,"title":619,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-helloworld","Docker - HelloWorld",{"path":621,"title":622,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-install","Docker - 安装",{"path":624,"title":625,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-introduce","Docker - 简介",{"path":627,"title":628,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-object","Docker - 镜像、容器、仓库",{"path":630,"title":631,"description":632},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-warehouse","Docker - 仓库管理","仓库是集中存放资源的地方，代码仓库是存放代码的，那么Docker 中的仓库就是存放 Docker 镜像的。",{"path":634,"title":635,"description":636},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-web-containers","Docker - WEB应用实例","在之前的章节中，仅对普通容器进行了演示，但在实际中常常使用到 Docker 容器中的 WEB 应用程序。",{"path":638,"title":639,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-config","Kubernetes - ConfigMap 与 Secret",{"path":641,"title":642,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm","Kubernetes - Helm 包管理",{"path":644,"title":645,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-install","Kubernetes - 集群安装",{"path":647,"title":648,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-introduction","Kubernetes - 简介与架构",{"path":650,"title":651,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-kubectl","Kubernetes - kubectl 命令行工具",{"path":653,"title":654,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-monitoring","Kubernetes - 监控与日志",{"path":656,"title":657,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-network-security","Kubernetes - 网络与安全",{"path":659,"title":660,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-service","Kubernetes - Service 与 Ingress",{"path":662,"title":663,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-storage","Kubernetes - 持久化存储",{"path":665,"title":666,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-workload","Kubernetes - 工作负载资源",{"path":668,"title":669,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-bash","Linux - Bash 基础语法",{"path":671,"title":672,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-file-directory","Linux - 文件与目录操作",{"path":674,"title":675,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-network","Linux - 网络配置",{"path":677,"title":678,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-package","Linux - 软件包管理",{"path":680,"title":681,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-process","Linux - 进程管理",{"path":683,"title":684,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-scripts","Linux - 常用脚本示例",{"path":686,"title":687,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-service","Linux - 服务管理",{"path":689,"title":690,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission","Linux - 用户与权限管理",{"path":692,"title":693,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-https","Nginx - HTTPS 配置",{"path":695,"title":696,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install","Nginx - 安装与配置",{"path":698,"title":699,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-loadbalance","Nginx - 负载均衡",{"path":701,"title":702,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-optimization","Nginx - 性能优化",{"path":704,"title":705,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-proxy","Nginx - 反向代理",{"path":707,"title":708,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-static","Nginx - 静态资源服务",{"path":710,"title":711,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-vhost","Nginx - 虚拟主机配置",{"path":713,"title":714,"description":715},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-architecture","MySQL 高可用架构","主从复制、读写分离、分库分表。",{"path":717,"title":718,"description":719},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-index","MySQL 索引","索引是帮助 MySQL 高效获取数据的有序数据结构。",{"path":721,"title":722,"description":723},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-lock","MySQL 锁","锁用于解决并发访问时的数据一致性问题。",{"path":725,"title":726,"description":727},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-optimize","MySQL 性能优化","SQL 优化是后端开发必备技能。",{"path":729,"title":730,"description":731},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-transaction","MySQL 事务","事务是一组不可分割的操作，要么全部成功，要么全部失败。",{"path":733,"title":734,"description":735},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-advanced","SQL 进阶","多表查询、子查询、函数、视图、存储过程。",{"path":737,"title":738,"description":739},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic","SQL 基础","SQL（Structured Query Language）是操作关系型数据库的标准语言。",{"path":741,"title":742,"description":743},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-advanced","Redis 进阶功能","事务、发布订阅、Lua 脚本、Pipeline。",{"path":745,"title":746,"description":747},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-basic","Redis 基础","Redis 安装配置与基本命令。",{"path":749,"title":750,"description":751},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-cluster","Redis 高可用","主从复制、哨兵、Cluster 集群。",{"path":753,"title":754,"description":755},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-datatype","Redis 数据类型","Redis 5 种基本数据类型 + 4 种特殊类型。",{"path":757,"title":758,"description":759},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-optimize","Redis 性能优化","内存优化、缓存问题、最佳实践。",{"path":761,"title":762,"description":763},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-persistence","Redis 持久化","Redis 提供 RDB 和 AOF 两种持久化方式。",{"path":765,"title":766,"description":767},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-principle","Redis 底层原理","数据结构、线程模型、网络模型。",{"path":769,"title":770,"description":771},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fbehaiver-patterns\u002Fobserver-pattern","观察者模式","观察者模式属于行为型模式，定义了对象之间的一对多的依赖关系，在这种模式中，当一个对象的状态发生变化时，所有依赖于它的对象都会得到通知，并且执行相关操作。观察者模式又被成为“发布—订阅模式”，即发布者发生改变后，会通知所有订阅者。",{"path":773,"title":774,"description":11},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Ffactory-pattern","工厂模式",{"path":776,"title":777,"description":778},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Fsingleton-pattern","单例模式","单例模式是最常用的设计模式之一，他可以保证在整个应用中，某个类只存在一个实例化对象，即全局使用到该类的只有一个对象，这种模式在需要限制某些类的实例数量时非常有用，通常全局只需要一个该对象即可，如一些配置文件映射对象、数据库连接对象等。",{"path":780,"title":781,"description":782},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fstructural-patterns\u002Fadapter-pattern","适配器模式","适配器模式是一种结构型模式，可以将一个类的接口转换成客户端所期望的另一种接口，适配器模式可以帮助开发人员在不修改现有代码的情况下，将不兼容的类组合在一起。",{"path":784,"title":785,"description":786},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-basic-operations","Git 创建版本库","在 Git 上创建版本库有两种方式，一种是直接拷贝远程 Git 仓库到本地，另外一种是我们自己创建本地的版本库。",{"path":788,"title":789,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-branch-manage","Git 分支管理",{"path":791,"title":792,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-content-operations","Git 仓库内容操作",{"path":794,"title":795,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-introduce-install","Git 介绍和安装",{"path":797,"title":798,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-remote-manage","Git 远程管理",{"path":800,"title":801,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-workspace-index-repo","Git 工作原理",{"path":803,"title":804,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fhomebrew","HomeBrew 教程",{"path":806,"title":807,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fidea\u002Fshortcuts","快捷键",{"path":809,"title":810,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fmaven\u002Fintroduce-install-config","Maven - 介绍、安装、配置",{"path":812,"title":813,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fbasic-knowledge","2. 基础知识",{"path":815,"title":816,"description":817},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomponent-communication","9. 组件通信","在前面的章节内，介绍了 Vue 中最核心的内容——组件的介绍和使用，和 Java 等编程语言相反，组件并不近似于这些变成语言中的类，类可以通过类或者其实例化的对象来相互交互，但 Vue 组件之间的作用域是相互独立的，这就意味着不同组件之间的数据无法相互引用。",{"path":819,"title":820,"description":821},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomputed","4. 计算属性","虽然直接在模板中使用表达式方便，但是如果在模板中添加很多逻辑，会让模板变的臃肿且难维护，耦合度较高。有没有一种简单的方式来实现呢？答案是有的。",{"path":823,"title":824,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcreate-vue-project","1. 环境搭建及安装",{"path":826,"title":827,"description":828},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Flife-cycle","6. 生命周期","生命周期是指组件从创建、挂载、更新到销毁的整个过程中所经历的一系列阶段。在 Vue 中，每个组件都有自己的生命周期，可以通过生命周期钩子函数来监听和处理组件在不同阶段的行为和状态。",{"path":830,"title":831,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fother-api","10. 其他 API",{"path":833,"title":834,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fpinia","8. Pinia",{"path":836,"title":837,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter","7. 路由",{"path":839,"title":840,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar","3. 指令及模板语法",{"path":842,"title":843,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fvue3-new-component","11. Vue3 新组件",{"path":845,"title":846,"description":847},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fwatch","5. 监视","Watch 是 Vue 提供的一个用于监视响应式数据变化并执行相应操作的 API，能够对响应式数据的变化做出一些操作的功能。Vue3 中的 Watch 支持多种用法，包括监视响应式对象、ref 对象、数组、函数等。",{"path":849,"title":850,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-introduction","Kafka 简介与安装",{"path":852,"title":853,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-producer-consumer","Kafka 生产者与消费者",{"path":855,"title":856,"description":857},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-springboot","Spring Boot 整合 Kafka","Spring Kafka 提供了对 Apache Kafka 的便捷集成。",{"path":859,"title":860,"description":861},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-exchange","RabbitMQ Exchange 详解","Exchange（交换机）是 RabbitMQ 的核心组件，负责接收生产者发送的消息，并根据规则将消息路由到一个或多个队列。",{"path":863,"title":864,"description":11},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-introduction","RabbitMQ 简介与安装",{"path":866,"title":867,"description":868},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-reliability","RabbitMQ 消息可靠性","消息可靠性是消息队列的核心要求，RabbitMQ 提供了多种机制来保证消息不丢失。",{"path":870,"title":871,"description":872},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-springboot","Spring Boot 整合 RabbitMQ","Spring AMQP 提供了对 RabbitMQ 的便捷集成，大大简化了开发工作。",{"path":874,"title":875,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-client","RocketMQ 客户端使用",{"path":877,"title":878,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-concepts","RocketMQ 核心概念",{"path":880,"title":881,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-installation","RocketMQ 安装部署",{"path":883,"title":884,"description":885},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-message-type","RocketMQ 消息类型","RocketMQ 支持多种消息类型，满足不同业务场景需求。",{"id":887,"title":14,"body":888,"description":15,"extension":3020,"meta":3021,"navigation":1256,"path":13,"seo":3022,"stem":3023,"__hash__":3024},"docs\u002Fai\u002Fagent\u002Fframeworks.md",{"type":889,"value":890,"toc":2994},"minimark",[891,895,899,1038,1042,1047,1050,1056,1090,1094,1098,1101,1112,1117,1143,1147,1150,1771,1775,1779,1786,1789,1809,2074,2077,2080,2087,2089,2115,2426,2430,2441,2444,2451,2454,2480,2811,2814,2817,2824,2827,2859,2865,2868,2871,2874,2877,2883,2886,2977,2981,2984,2990],[892,893,894],"h2",{"id":894},"框架概览",[896,897,898],"p",{},"随着 AI Agent 技术的快速发展，社区涌现出多种 Agent 开发框架。选择合适的框架可以大幅提升开发效率。下表对主流框架进行对比：",[900,901,902,927],"table",{},[903,904,905],"thead",{},[906,907,908,912,915,918,921,924],"tr",{},[909,910,911],"th",{},"框架",[909,913,914],{},"核心定位",[909,916,917],{},"编程语言",[909,919,920],{},"Agent 模式",[909,922,923],{},"学习曲线",[909,925,926],{},"社区活跃度",[928,929,930,954,974,995,1017],"tbody",{},[906,931,932,939,942,945,948,951],{},[933,934,935],"td",{},[936,937,938],"strong",{},"LangChain \u002F LangGraph",[933,940,941],{},"通用 Agent 编排",[933,943,944],{},"Python, JS\u002FTS",[933,946,947],{},"单\u002F多 Agent，图状态机",[933,949,950],{},"中等",[933,952,953],{},"非常高",[906,955,956,961,964,966,969,971],{},[933,957,958],{},[936,959,960],{},"LlamaIndex",[933,962,963],{},"数据驱动 Agent",[933,965,944],{},[933,967,968],{},"单 Agent，数据查询",[933,970,950],{},[933,972,973],{},"高",[906,975,976,981,984,987,990,993],{},[933,977,978],{},[936,979,980],{},"AutoGen",[933,982,983],{},"多 Agent 对话",[933,985,986],{},"Python, .NET",[933,988,989],{},"多 Agent 协作",[933,991,992],{},"较高",[933,994,973],{},[906,996,997,1002,1005,1008,1011,1014],{},[933,998,999],{},[936,1000,1001],{},"CrewAI",[933,1003,1004],{},"角色化团队协作",[933,1006,1007],{},"Python",[933,1009,1010],{},"多 Agent，角色扮演",[933,1012,1013],{},"较低",[933,1015,1016],{},"中高",[906,1018,1019,1024,1027,1030,1033,1036],{},[933,1020,1021],{},[936,1022,1023],{},"Dify",[933,1025,1026],{},"低代码\u002F可视化",[933,1028,1029],{},"Python (后端)",[933,1031,1032],{},"可视化 Agent 构建",[933,1034,1035],{},"低",[933,1037,973],{},[892,1039,1041],{"id":1040},"langchain-与-langgraph","LangChain 与 LangGraph",[1043,1044,1046],"h3",{"id":1045},"langchain-简介","LangChain 简介",[896,1048,1049],{},"LangChain 是最早也是最知名的 LLM 应用开发框架之一。它提供了丰富的抽象层来简化与大语言模型的交互。",[896,1051,1052,1055],{},[936,1053,1054],{},"核心概念","：",[1057,1058,1059,1066,1072,1078,1084],"ul",{},[1060,1061,1062,1065],"li",{},[936,1063,1064],{},"Model","：对 LLM 的统一封装，支持 OpenAI、Anthropic、本地模型等",[1060,1067,1068,1071],{},[936,1069,1070],{},"Prompt Template","：可复用的提示词模板",[1060,1073,1074,1077],{},[936,1075,1076],{},"Chain","：将多个组件串联成处理流水线",[1060,1079,1080,1083],{},[936,1081,1082],{},"Tool","：供 Agent 调用的外部工具",[1060,1085,1086,1089],{},[936,1087,1088],{},"Memory","：对话历史和状态管理",[1091,1092,1093],"note",{},"\nLangChain 在早期版本中使用 `AgentExecutor` 来运行 Agent，但现在官方推荐使用 **LangGraph** 来构建更灵活的 Agent 工作流。LangGraph 是 LangChain 生态的一部分，专注于状态化、可控的 Agent 编排。\n",[1043,1095,1097],{"id":1096},"langgraph-核心架构","LangGraph 核心架构",[896,1099,1100],{},"LangGraph 采用**有向图（Directed Graph）**的方式来定义 Agent 的工作流。每个节点是一个处理步骤，边定义了状态转移的条件。",[1102,1103,1109],"pre",{"className":1104,"code":1106,"language":1107,"meta":1108},[1105],"language-text","flowchart LR\n    START[\"START\"] --> Agent[\"Agent 节点\"]\n    Agent --> Cond{\"工具调用？\"}\n    Cond -->|是| Tools[\"工具执行\"]\n    Cond -->|否| END[\"END\"]\n    Tools --> Agent\n","text","mermaid",[1110,1111,1106],"code",{"__ignoreMap":11},[896,1113,1114,1055],{},[936,1115,1116],{},"LangGraph 的关键概念",[1057,1118,1119,1125,1131,1137],{},[1060,1120,1121,1124],{},[936,1122,1123],{},"State（状态）","：在图中流转的数据结构，所有节点共享并修改同一个状态",[1060,1126,1127,1130],{},[936,1128,1129],{},"Node（节点）","：执行具体逻辑的函数，接收状态并返回更新后的状态",[1060,1132,1133,1136],{},[936,1134,1135],{},"Edge（边）","：连接节点，可以是固定路径或条件分支",[1060,1138,1139,1142],{},[936,1140,1141],{},"Checkpointing","：内置状态持久化，支持中断和恢复",[1043,1144,1146],{"id":1145},"langgraph-代码示例","LangGraph 代码示例",[896,1148,1149],{},"以下是使用 LangGraph 构建一个带有工具调用能力的简单 Agent：",[1102,1151,1155],{"className":1152,"code":1153,"language":1154,"meta":11,"style":11},"language-python shiki shiki-themes github-light github-light github-dark","from typing import Annotated, TypedDict\nfrom langgraph.graph import StateGraph, START, END\nfrom langgraph.graph.message import add_messages\nfrom langgraph.prebuilt import ToolNode, tools_condition\nfrom langchain_openai import ChatOpenAI\nfrom langchain_core.tools import tool\n\n# 1. 定义状态\nclass AgentState(TypedDict):\n    messages: Annotated[list, add_messages]\n\n# 2. 定义工具\n@tool\ndef search_web(query: str) -> str:\n    \"\"\"搜索互联网获取最新信息\"\"\"\n    # 实际项目中调用搜索 API\n    return f\"搜索 '{query}' 的结果：这里是搜索到的相关信息...\"\n\n@tool\ndef calculator(expression: str) -> str:\n    \"\"\"计算数学表达式\"\"\"\n    try:\n        result = eval(expression)\n        return f\"计算结果：{result}\"\n    except Exception as e:\n        return f\"计算错误：{e}\"\n\n# 3. 配置模型\ntools = [search_web, calculator]\nllm = ChatOpenAI(model=\"gpt-4o\").bind_tools(tools)\n\n# 4. 定义节点\ndef agent_node(state: AgentState):\n    response = llm.invoke(state[\"messages\"])\n    return {\"messages\": [response]}\n\n# 5. 构建图\ngraph = StateGraph(AgentState)\ngraph.add_node(\"agent\", agent_node)\ngraph.add_node(\"tools\", ToolNode(tools))\n\n# 6. 定义边\ngraph.add_edge(START, \"agent\")\ngraph.add_conditional_edges(\"agent\", tools_condition)\ngraph.add_edge(\"tools\", \"agent\")\n\n# 7. 编译并运行\napp = graph.compile()\n\n# 使用 Agent\nresult = app.invoke({\n    \"messages\": [(\"user\", \"帮我计算 (125 * 37) + 892 的结果\")]\n})\nprint(result[\"messages\"][-1].content)\n","python",[1110,1156,1157,1176,1199,1212,1225,1238,1251,1258,1265,1284,1296,1301,1307,1313,1336,1343,1349,1373,1378,1383,1402,1408,1416,1431,1452,1467,1486,1491,1497,1508,1531,1536,1542,1553,1570,1583,1588,1594,1605,1617,1628,1633,1639,1654,1665,1678,1683,1689,1700,1705,1711,1722,1742,1748],{"__ignoreMap":11},[1158,1159,1162,1166,1170,1173],"span",{"class":1160,"line":1161},"line",1,[1158,1163,1165],{"class":1164},"s8jYJ","from",[1158,1167,1169],{"class":1168},"sxrX7"," typing ",[1158,1171,1172],{"class":1164},"import",[1158,1174,1175],{"class":1168}," Annotated, TypedDict\n",[1158,1177,1179,1181,1184,1186,1189,1193,1196],{"class":1160,"line":1178},2,[1158,1180,1165],{"class":1164},[1158,1182,1183],{"class":1168}," langgraph.graph ",[1158,1185,1172],{"class":1164},[1158,1187,1188],{"class":1168}," StateGraph, ",[1158,1190,1192],{"class":1191},"sBjJW","START",[1158,1194,1195],{"class":1168},", ",[1158,1197,1198],{"class":1191},"END\n",[1158,1200,1202,1204,1207,1209],{"class":1160,"line":1201},3,[1158,1203,1165],{"class":1164},[1158,1205,1206],{"class":1168}," langgraph.graph.message ",[1158,1208,1172],{"class":1164},[1158,1210,1211],{"class":1168}," add_messages\n",[1158,1213,1215,1217,1220,1222],{"class":1160,"line":1214},4,[1158,1216,1165],{"class":1164},[1158,1218,1219],{"class":1168}," langgraph.prebuilt ",[1158,1221,1172],{"class":1164},[1158,1223,1224],{"class":1168}," ToolNode, tools_condition\n",[1158,1226,1228,1230,1233,1235],{"class":1160,"line":1227},5,[1158,1229,1165],{"class":1164},[1158,1231,1232],{"class":1168}," langchain_openai ",[1158,1234,1172],{"class":1164},[1158,1236,1237],{"class":1168}," ChatOpenAI\n",[1158,1239,1241,1243,1246,1248],{"class":1160,"line":1240},6,[1158,1242,1165],{"class":1164},[1158,1244,1245],{"class":1168}," langchain_core.tools ",[1158,1247,1172],{"class":1164},[1158,1249,1250],{"class":1168}," tool\n",[1158,1252,1254],{"class":1160,"line":1253},7,[1158,1255,1257],{"emptyLinePlaceholder":1256},true,"\n",[1158,1259,1261],{"class":1160,"line":1260},8,[1158,1262,1264],{"class":1263},"sCsY4","# 1. 定义状态\n",[1158,1266,1268,1271,1275,1278,1281],{"class":1160,"line":1267},9,[1158,1269,1270],{"class":1164},"class",[1158,1272,1274],{"class":1273},"snPdu"," AgentState",[1158,1276,1277],{"class":1168},"(",[1158,1279,1280],{"class":1273},"TypedDict",[1158,1282,1283],{"class":1168},"):\n",[1158,1285,1287,1290,1293],{"class":1160,"line":1286},10,[1158,1288,1289],{"class":1168},"    messages: Annotated[",[1158,1291,1292],{"class":1191},"list",[1158,1294,1295],{"class":1168},", add_messages]\n",[1158,1297,1299],{"class":1160,"line":1298},11,[1158,1300,1257],{"emptyLinePlaceholder":1256},[1158,1302,1304],{"class":1160,"line":1303},12,[1158,1305,1306],{"class":1263},"# 2. 定义工具\n",[1158,1308,1310],{"class":1160,"line":1309},13,[1158,1311,1312],{"class":1273},"@tool\n",[1158,1314,1316,1319,1322,1325,1328,1331,1333],{"class":1160,"line":1315},14,[1158,1317,1318],{"class":1164},"def",[1158,1320,1321],{"class":1273}," search_web",[1158,1323,1324],{"class":1168},"(query: ",[1158,1326,1327],{"class":1191},"str",[1158,1329,1330],{"class":1168},") -> ",[1158,1332,1327],{"class":1191},[1158,1334,1335],{"class":1168},":\n",[1158,1337,1339],{"class":1160,"line":1338},15,[1158,1340,1342],{"class":1341},"sIIMD","    \"\"\"搜索互联网获取最新信息\"\"\"\n",[1158,1344,1346],{"class":1160,"line":1345},16,[1158,1347,1348],{"class":1263},"    # 实际项目中调用搜索 API\n",[1158,1350,1352,1355,1358,1361,1364,1367,1370],{"class":1160,"line":1351},17,[1158,1353,1354],{"class":1164},"    return",[1158,1356,1357],{"class":1164}," f",[1158,1359,1360],{"class":1341},"\"搜索 '",[1158,1362,1363],{"class":1191},"{",[1158,1365,1366],{"class":1168},"query",[1158,1368,1369],{"class":1191},"}",[1158,1371,1372],{"class":1341},"' 的结果：这里是搜索到的相关信息...\"\n",[1158,1374,1376],{"class":1160,"line":1375},18,[1158,1377,1257],{"emptyLinePlaceholder":1256},[1158,1379,1381],{"class":1160,"line":1380},19,[1158,1382,1312],{"class":1273},[1158,1384,1386,1388,1391,1394,1396,1398,1400],{"class":1160,"line":1385},20,[1158,1387,1318],{"class":1164},[1158,1389,1390],{"class":1273}," calculator",[1158,1392,1393],{"class":1168},"(expression: ",[1158,1395,1327],{"class":1191},[1158,1397,1330],{"class":1168},[1158,1399,1327],{"class":1191},[1158,1401,1335],{"class":1168},[1158,1403,1405],{"class":1160,"line":1404},21,[1158,1406,1407],{"class":1341},"    \"\"\"计算数学表达式\"\"\"\n",[1158,1409,1411,1414],{"class":1160,"line":1410},22,[1158,1412,1413],{"class":1164},"    try",[1158,1415,1335],{"class":1168},[1158,1417,1419,1422,1425,1428],{"class":1160,"line":1418},23,[1158,1420,1421],{"class":1168},"        result ",[1158,1423,1424],{"class":1164},"=",[1158,1426,1427],{"class":1191}," eval",[1158,1429,1430],{"class":1168},"(expression)\n",[1158,1432,1434,1437,1439,1442,1444,1447,1449],{"class":1160,"line":1433},24,[1158,1435,1436],{"class":1164},"        return",[1158,1438,1357],{"class":1164},[1158,1440,1441],{"class":1341},"\"计算结果：",[1158,1443,1363],{"class":1191},[1158,1445,1446],{"class":1168},"result",[1158,1448,1369],{"class":1191},[1158,1450,1451],{"class":1341},"\"\n",[1158,1453,1455,1458,1461,1464],{"class":1160,"line":1454},25,[1158,1456,1457],{"class":1164},"    except",[1158,1459,1460],{"class":1191}," Exception",[1158,1462,1463],{"class":1164}," as",[1158,1465,1466],{"class":1168}," e:\n",[1158,1468,1470,1472,1474,1477,1479,1482,1484],{"class":1160,"line":1469},26,[1158,1471,1436],{"class":1164},[1158,1473,1357],{"class":1164},[1158,1475,1476],{"class":1341},"\"计算错误：",[1158,1478,1363],{"class":1191},[1158,1480,1481],{"class":1168},"e",[1158,1483,1369],{"class":1191},[1158,1485,1451],{"class":1341},[1158,1487,1489],{"class":1160,"line":1488},27,[1158,1490,1257],{"emptyLinePlaceholder":1256},[1158,1492,1494],{"class":1160,"line":1493},28,[1158,1495,1496],{"class":1263},"# 3. 配置模型\n",[1158,1498,1500,1503,1505],{"class":1160,"line":1499},29,[1158,1501,1502],{"class":1168},"tools ",[1158,1504,1424],{"class":1164},[1158,1506,1507],{"class":1168}," [search_web, calculator]\n",[1158,1509,1511,1514,1516,1519,1523,1525,1528],{"class":1160,"line":1510},30,[1158,1512,1513],{"class":1168},"llm ",[1158,1515,1424],{"class":1164},[1158,1517,1518],{"class":1168}," ChatOpenAI(",[1158,1520,1522],{"class":1521},"sP4rz","model",[1158,1524,1424],{"class":1164},[1158,1526,1527],{"class":1341},"\"gpt-4o\"",[1158,1529,1530],{"class":1168},").bind_tools(tools)\n",[1158,1532,1534],{"class":1160,"line":1533},31,[1158,1535,1257],{"emptyLinePlaceholder":1256},[1158,1537,1539],{"class":1160,"line":1538},32,[1158,1540,1541],{"class":1263},"# 4. 定义节点\n",[1158,1543,1545,1547,1550],{"class":1160,"line":1544},33,[1158,1546,1318],{"class":1164},[1158,1548,1549],{"class":1273}," agent_node",[1158,1551,1552],{"class":1168},"(state: AgentState):\n",[1158,1554,1556,1559,1561,1564,1567],{"class":1160,"line":1555},34,[1158,1557,1558],{"class":1168},"    response ",[1158,1560,1424],{"class":1164},[1158,1562,1563],{"class":1168}," llm.invoke(state[",[1158,1565,1566],{"class":1341},"\"messages\"",[1158,1568,1569],{"class":1168},"])\n",[1158,1571,1573,1575,1578,1580],{"class":1160,"line":1572},35,[1158,1574,1354],{"class":1164},[1158,1576,1577],{"class":1168}," {",[1158,1579,1566],{"class":1341},[1158,1581,1582],{"class":1168},": [response]}\n",[1158,1584,1586],{"class":1160,"line":1585},36,[1158,1587,1257],{"emptyLinePlaceholder":1256},[1158,1589,1591],{"class":1160,"line":1590},37,[1158,1592,1593],{"class":1263},"# 5. 构建图\n",[1158,1595,1597,1600,1602],{"class":1160,"line":1596},38,[1158,1598,1599],{"class":1168},"graph ",[1158,1601,1424],{"class":1164},[1158,1603,1604],{"class":1168}," StateGraph(AgentState)\n",[1158,1606,1608,1611,1614],{"class":1160,"line":1607},39,[1158,1609,1610],{"class":1168},"graph.add_node(",[1158,1612,1613],{"class":1341},"\"agent\"",[1158,1615,1616],{"class":1168},", agent_node)\n",[1158,1618,1620,1622,1625],{"class":1160,"line":1619},40,[1158,1621,1610],{"class":1168},[1158,1623,1624],{"class":1341},"\"tools\"",[1158,1626,1627],{"class":1168},", ToolNode(tools))\n",[1158,1629,1631],{"class":1160,"line":1630},41,[1158,1632,1257],{"emptyLinePlaceholder":1256},[1158,1634,1636],{"class":1160,"line":1635},42,[1158,1637,1638],{"class":1263},"# 6. 定义边\n",[1158,1640,1642,1645,1647,1649,1651],{"class":1160,"line":1641},43,[1158,1643,1644],{"class":1168},"graph.add_edge(",[1158,1646,1192],{"class":1191},[1158,1648,1195],{"class":1168},[1158,1650,1613],{"class":1341},[1158,1652,1653],{"class":1168},")\n",[1158,1655,1657,1660,1662],{"class":1160,"line":1656},44,[1158,1658,1659],{"class":1168},"graph.add_conditional_edges(",[1158,1661,1613],{"class":1341},[1158,1663,1664],{"class":1168},", tools_condition)\n",[1158,1666,1668,1670,1672,1674,1676],{"class":1160,"line":1667},45,[1158,1669,1644],{"class":1168},[1158,1671,1624],{"class":1341},[1158,1673,1195],{"class":1168},[1158,1675,1613],{"class":1341},[1158,1677,1653],{"class":1168},[1158,1679,1681],{"class":1160,"line":1680},46,[1158,1682,1257],{"emptyLinePlaceholder":1256},[1158,1684,1686],{"class":1160,"line":1685},47,[1158,1687,1688],{"class":1263},"# 7. 编译并运行\n",[1158,1690,1692,1695,1697],{"class":1160,"line":1691},48,[1158,1693,1694],{"class":1168},"app ",[1158,1696,1424],{"class":1164},[1158,1698,1699],{"class":1168}," graph.compile()\n",[1158,1701,1703],{"class":1160,"line":1702},49,[1158,1704,1257],{"emptyLinePlaceholder":1256},[1158,1706,1708],{"class":1160,"line":1707},50,[1158,1709,1710],{"class":1263},"# 使用 Agent\n",[1158,1712,1714,1717,1719],{"class":1160,"line":1713},51,[1158,1715,1716],{"class":1168},"result ",[1158,1718,1424],{"class":1164},[1158,1720,1721],{"class":1168}," app.invoke({\n",[1158,1723,1725,1728,1731,1734,1736,1739],{"class":1160,"line":1724},52,[1158,1726,1727],{"class":1341},"    \"messages\"",[1158,1729,1730],{"class":1168},": [(",[1158,1732,1733],{"class":1341},"\"user\"",[1158,1735,1195],{"class":1168},[1158,1737,1738],{"class":1341},"\"帮我计算 (125 * 37) + 892 的结果\"",[1158,1740,1741],{"class":1168},")]\n",[1158,1743,1745],{"class":1160,"line":1744},53,[1158,1746,1747],{"class":1168},"})\n",[1158,1749,1751,1754,1757,1759,1762,1765,1768],{"class":1160,"line":1750},54,[1158,1752,1753],{"class":1191},"print",[1158,1755,1756],{"class":1168},"(result[",[1158,1758,1566],{"class":1341},[1158,1760,1761],{"class":1168},"][",[1158,1763,1764],{"class":1164},"-",[1158,1766,1767],{"class":1191},"1",[1158,1769,1770],{"class":1168},"].content)\n",[1772,1773,1774],"tip",{},"\nLangGraph 的核心优势在于**可控性**。通过显式定义图结构，开发者能够精确控制 Agent 的执行流程，添加人工审批节点、设置超时、限制工具调用次数等。\n",[892,1776,1778],{"id":1777},"llamaindex-agents","LlamaIndex Agents",[896,1780,1781,1782,1785],{},"LlamaIndex 最初以 RAG（检索增强生成）著称，后来扩展出了 Agent 能力。它的 Agent 特别擅长",[936,1783,1784],{},"数据查询和知识密集型任务","。",[1043,1787,1788],{"id":1788},"核心特点",[1057,1790,1791,1797,1803],{},[1060,1792,1793,1796],{},[936,1794,1795],{},"数据连接器","：支持 PDF、数据库、API 等多种数据源",[1060,1798,1799,1802],{},[936,1800,1801],{},"索引结构","：多种索引类型优化不同查询模式",[1060,1804,1805,1808],{},[936,1806,1807],{},"查询引擎","：将数据检索能力封装为 Agent 可调用的工具",[1102,1810,1812],{"className":1152,"code":1811,"language":1154,"meta":11,"style":11},"from llama_index.core.agent import ReActAgent\nfrom llama_index.llms.openai import OpenAI\nfrom llama_index.core.tools import QueryEngineTool, FunctionTool\n\n# 将索引查询引擎包装为工具\nquery_tool = QueryEngineTool.from_defaults(\n    query_engine=index.as_query_engine(),\n    name=\"knowledge_base\",\n    description=\"查询内部知识库获取公司文档信息\"\n)\n\n# 自定义函数工具\ndef send_email(to: str, subject: str, body: str) -> str:\n    \"\"\"发送邮件通知\"\"\"\n    # 实际邮件发送逻辑\n    return f\"邮件已发送至 {to}\"\n\nemail_tool = FunctionTool.from_defaults(fn=send_email)\n\n# 创建 ReAct Agent\nagent = ReActAgent.from_tools(\n    tools=[query_tool, email_tool],\n    llm=OpenAI(model=\"gpt-4o\"),\n    verbose=True\n)\n\nresponse = agent.chat(\"查询最新的项目报告并发送给团队负责人\")\n",[1110,1813,1814,1826,1838,1850,1854,1859,1869,1879,1892,1902,1906,1910,1915,1943,1948,1953,1971,1975,1993,1997,2002,2012,2022,2041,2051,2055,2059],{"__ignoreMap":11},[1158,1815,1816,1818,1821,1823],{"class":1160,"line":1161},[1158,1817,1165],{"class":1164},[1158,1819,1820],{"class":1168}," llama_index.core.agent ",[1158,1822,1172],{"class":1164},[1158,1824,1825],{"class":1168}," ReActAgent\n",[1158,1827,1828,1830,1833,1835],{"class":1160,"line":1178},[1158,1829,1165],{"class":1164},[1158,1831,1832],{"class":1168}," llama_index.llms.openai ",[1158,1834,1172],{"class":1164},[1158,1836,1837],{"class":1168}," OpenAI\n",[1158,1839,1840,1842,1845,1847],{"class":1160,"line":1201},[1158,1841,1165],{"class":1164},[1158,1843,1844],{"class":1168}," llama_index.core.tools ",[1158,1846,1172],{"class":1164},[1158,1848,1849],{"class":1168}," QueryEngineTool, FunctionTool\n",[1158,1851,1852],{"class":1160,"line":1214},[1158,1853,1257],{"emptyLinePlaceholder":1256},[1158,1855,1856],{"class":1160,"line":1227},[1158,1857,1858],{"class":1263},"# 将索引查询引擎包装为工具\n",[1158,1860,1861,1864,1866],{"class":1160,"line":1240},[1158,1862,1863],{"class":1168},"query_tool ",[1158,1865,1424],{"class":1164},[1158,1867,1868],{"class":1168}," QueryEngineTool.from_defaults(\n",[1158,1870,1871,1874,1876],{"class":1160,"line":1253},[1158,1872,1873],{"class":1521},"    query_engine",[1158,1875,1424],{"class":1164},[1158,1877,1878],{"class":1168},"index.as_query_engine(),\n",[1158,1880,1881,1884,1886,1889],{"class":1160,"line":1260},[1158,1882,1883],{"class":1521},"    name",[1158,1885,1424],{"class":1164},[1158,1887,1888],{"class":1341},"\"knowledge_base\"",[1158,1890,1891],{"class":1168},",\n",[1158,1893,1894,1897,1899],{"class":1160,"line":1267},[1158,1895,1896],{"class":1521},"    description",[1158,1898,1424],{"class":1164},[1158,1900,1901],{"class":1341},"\"查询内部知识库获取公司文档信息\"\n",[1158,1903,1904],{"class":1160,"line":1286},[1158,1905,1653],{"class":1168},[1158,1907,1908],{"class":1160,"line":1298},[1158,1909,1257],{"emptyLinePlaceholder":1256},[1158,1911,1912],{"class":1160,"line":1303},[1158,1913,1914],{"class":1263},"# 自定义函数工具\n",[1158,1916,1917,1919,1922,1925,1927,1930,1932,1935,1937,1939,1941],{"class":1160,"line":1309},[1158,1918,1318],{"class":1164},[1158,1920,1921],{"class":1273}," send_email",[1158,1923,1924],{"class":1168},"(to: ",[1158,1926,1327],{"class":1191},[1158,1928,1929],{"class":1168},", subject: ",[1158,1931,1327],{"class":1191},[1158,1933,1934],{"class":1168},", body: ",[1158,1936,1327],{"class":1191},[1158,1938,1330],{"class":1168},[1158,1940,1327],{"class":1191},[1158,1942,1335],{"class":1168},[1158,1944,1945],{"class":1160,"line":1315},[1158,1946,1947],{"class":1341},"    \"\"\"发送邮件通知\"\"\"\n",[1158,1949,1950],{"class":1160,"line":1338},[1158,1951,1952],{"class":1263},"    # 实际邮件发送逻辑\n",[1158,1954,1955,1957,1959,1962,1964,1967,1969],{"class":1160,"line":1345},[1158,1956,1354],{"class":1164},[1158,1958,1357],{"class":1164},[1158,1960,1961],{"class":1341},"\"邮件已发送至 ",[1158,1963,1363],{"class":1191},[1158,1965,1966],{"class":1168},"to",[1158,1968,1369],{"class":1191},[1158,1970,1451],{"class":1341},[1158,1972,1973],{"class":1160,"line":1351},[1158,1974,1257],{"emptyLinePlaceholder":1256},[1158,1976,1977,1980,1982,1985,1988,1990],{"class":1160,"line":1375},[1158,1978,1979],{"class":1168},"email_tool ",[1158,1981,1424],{"class":1164},[1158,1983,1984],{"class":1168}," FunctionTool.from_defaults(",[1158,1986,1987],{"class":1521},"fn",[1158,1989,1424],{"class":1164},[1158,1991,1992],{"class":1168},"send_email)\n",[1158,1994,1995],{"class":1160,"line":1380},[1158,1996,1257],{"emptyLinePlaceholder":1256},[1158,1998,1999],{"class":1160,"line":1385},[1158,2000,2001],{"class":1263},"# 创建 ReAct Agent\n",[1158,2003,2004,2007,2009],{"class":1160,"line":1404},[1158,2005,2006],{"class":1168},"agent ",[1158,2008,1424],{"class":1164},[1158,2010,2011],{"class":1168}," ReActAgent.from_tools(\n",[1158,2013,2014,2017,2019],{"class":1160,"line":1410},[1158,2015,2016],{"class":1521},"    tools",[1158,2018,1424],{"class":1164},[1158,2020,2021],{"class":1168},"[query_tool, email_tool],\n",[1158,2023,2024,2027,2029,2032,2034,2036,2038],{"class":1160,"line":1418},[1158,2025,2026],{"class":1521},"    llm",[1158,2028,1424],{"class":1164},[1158,2030,2031],{"class":1168},"OpenAI(",[1158,2033,1522],{"class":1521},[1158,2035,1424],{"class":1164},[1158,2037,1527],{"class":1341},[1158,2039,2040],{"class":1168},"),\n",[1158,2042,2043,2046,2048],{"class":1160,"line":1433},[1158,2044,2045],{"class":1521},"    verbose",[1158,2047,1424],{"class":1164},[1158,2049,2050],{"class":1191},"True\n",[1158,2052,2053],{"class":1160,"line":1454},[1158,2054,1653],{"class":1168},[1158,2056,2057],{"class":1160,"line":1469},[1158,2058,1257],{"emptyLinePlaceholder":1256},[1158,2060,2061,2064,2066,2069,2072],{"class":1160,"line":1488},[1158,2062,2063],{"class":1168},"response ",[1158,2065,1424],{"class":1164},[1158,2067,2068],{"class":1168}," agent.chat(",[1158,2070,2071],{"class":1341},"\"查询最新的项目报告并发送给团队负责人\"",[1158,2073,1653],{"class":1168},[1091,2075,2076],{},"\n如果你的 Agent 核心需求是与大量数据交互（文档问答、知识库检索等），LlamaIndex 是比 LangChain 更专注的选择。\n",[892,2078,980],{"id":2079},"autogen",[896,2081,2082,2083,2086],{},"AutoGen 是微软推出的多 Agent 对话框架，核心理念是让多个 Agent 通过",[936,2084,2085],{},"结构化对话","协作完成任务。",[1043,2088,1054],{"id":1054},[1057,2090,2091,2097,2103,2109],{},[1060,2092,2093,2096],{},[936,2094,2095],{},"ConversableAgent","：可对话的 Agent 基类",[1060,2098,2099,2102],{},[936,2100,2101],{},"AssistantAgent","：基于 LLM 的助手 Agent",[1060,2104,2105,2108],{},[936,2106,2107],{},"UserProxyAgent","：代表用户的 Agent，可执行代码",[1060,2110,2111,2114],{},[936,2112,2113],{},"GroupChat","：多 Agent 群聊机制",[1102,2116,2118],{"className":1152,"code":2117,"language":1154,"meta":11,"style":11},"from autogen import AssistantAgent, UserProxyAgent, GroupChat, GroupChatManager\n\n# 创建多个专业 Agent\ncoder = AssistantAgent(\n    name=\"Coder\",\n    system_message=\"你是一位 Python 专家，负责编写高质量代码。\",\n    llm_config={\"model\": \"gpt-4o\"}\n)\n\nreviewer = AssistantAgent(\n    name=\"Reviewer\",\n    system_message=\"你是一位代码审查专家，负责审查代码质量和安全性。\",\n    llm_config={\"model\": \"gpt-4o\"}\n)\n\n# 用户代理（可执行代码）\nuser_proxy = UserProxyAgent(\n    name=\"User\",\n    human_input_mode=\"NEVER\",\n    code_execution_config={\"work_dir\": \"workspace\"}\n)\n\n# 创建群聊\ngroup_chat = GroupChat(\n    agents=[user_proxy, coder, reviewer],\n    messages=[],\n    max_round=10\n)\n\nmanager = GroupChatManager(groupchat=group_chat)\n\n# 发起任务\nuser_proxy.initiate_chat(\n    manager,\n    message=\"编写一个 Python 脚本来分析 CSV 文件中的销售数据并生成图表\"\n)\n",[1110,2119,2120,2132,2136,2141,2151,2162,2174,2194,2198,2202,2211,2222,2233,2249,2253,2257,2262,2272,2283,2295,2314,2318,2322,2327,2337,2347,2357,2367,2371,2375,2393,2397,2402,2407,2412,2422],{"__ignoreMap":11},[1158,2121,2122,2124,2127,2129],{"class":1160,"line":1161},[1158,2123,1165],{"class":1164},[1158,2125,2126],{"class":1168}," autogen ",[1158,2128,1172],{"class":1164},[1158,2130,2131],{"class":1168}," AssistantAgent, UserProxyAgent, GroupChat, GroupChatManager\n",[1158,2133,2134],{"class":1160,"line":1178},[1158,2135,1257],{"emptyLinePlaceholder":1256},[1158,2137,2138],{"class":1160,"line":1201},[1158,2139,2140],{"class":1263},"# 创建多个专业 Agent\n",[1158,2142,2143,2146,2148],{"class":1160,"line":1214},[1158,2144,2145],{"class":1168},"coder ",[1158,2147,1424],{"class":1164},[1158,2149,2150],{"class":1168}," AssistantAgent(\n",[1158,2152,2153,2155,2157,2160],{"class":1160,"line":1227},[1158,2154,1883],{"class":1521},[1158,2156,1424],{"class":1164},[1158,2158,2159],{"class":1341},"\"Coder\"",[1158,2161,1891],{"class":1168},[1158,2163,2164,2167,2169,2172],{"class":1160,"line":1240},[1158,2165,2166],{"class":1521},"    system_message",[1158,2168,1424],{"class":1164},[1158,2170,2171],{"class":1341},"\"你是一位 Python 专家，负责编写高质量代码。\"",[1158,2173,1891],{"class":1168},[1158,2175,2176,2179,2181,2183,2186,2189,2191],{"class":1160,"line":1253},[1158,2177,2178],{"class":1521},"    llm_config",[1158,2180,1424],{"class":1164},[1158,2182,1363],{"class":1168},[1158,2184,2185],{"class":1341},"\"model\"",[1158,2187,2188],{"class":1168},": ",[1158,2190,1527],{"class":1341},[1158,2192,2193],{"class":1168},"}\n",[1158,2195,2196],{"class":1160,"line":1260},[1158,2197,1653],{"class":1168},[1158,2199,2200],{"class":1160,"line":1267},[1158,2201,1257],{"emptyLinePlaceholder":1256},[1158,2203,2204,2207,2209],{"class":1160,"line":1286},[1158,2205,2206],{"class":1168},"reviewer ",[1158,2208,1424],{"class":1164},[1158,2210,2150],{"class":1168},[1158,2212,2213,2215,2217,2220],{"class":1160,"line":1298},[1158,2214,1883],{"class":1521},[1158,2216,1424],{"class":1164},[1158,2218,2219],{"class":1341},"\"Reviewer\"",[1158,2221,1891],{"class":1168},[1158,2223,2224,2226,2228,2231],{"class":1160,"line":1303},[1158,2225,2166],{"class":1521},[1158,2227,1424],{"class":1164},[1158,2229,2230],{"class":1341},"\"你是一位代码审查专家，负责审查代码质量和安全性。\"",[1158,2232,1891],{"class":1168},[1158,2234,2235,2237,2239,2241,2243,2245,2247],{"class":1160,"line":1309},[1158,2236,2178],{"class":1521},[1158,2238,1424],{"class":1164},[1158,2240,1363],{"class":1168},[1158,2242,2185],{"class":1341},[1158,2244,2188],{"class":1168},[1158,2246,1527],{"class":1341},[1158,2248,2193],{"class":1168},[1158,2250,2251],{"class":1160,"line":1315},[1158,2252,1653],{"class":1168},[1158,2254,2255],{"class":1160,"line":1338},[1158,2256,1257],{"emptyLinePlaceholder":1256},[1158,2258,2259],{"class":1160,"line":1345},[1158,2260,2261],{"class":1263},"# 用户代理（可执行代码）\n",[1158,2263,2264,2267,2269],{"class":1160,"line":1351},[1158,2265,2266],{"class":1168},"user_proxy ",[1158,2268,1424],{"class":1164},[1158,2270,2271],{"class":1168}," UserProxyAgent(\n",[1158,2273,2274,2276,2278,2281],{"class":1160,"line":1375},[1158,2275,1883],{"class":1521},[1158,2277,1424],{"class":1164},[1158,2279,2280],{"class":1341},"\"User\"",[1158,2282,1891],{"class":1168},[1158,2284,2285,2288,2290,2293],{"class":1160,"line":1380},[1158,2286,2287],{"class":1521},"    human_input_mode",[1158,2289,1424],{"class":1164},[1158,2291,2292],{"class":1341},"\"NEVER\"",[1158,2294,1891],{"class":1168},[1158,2296,2297,2300,2302,2304,2307,2309,2312],{"class":1160,"line":1385},[1158,2298,2299],{"class":1521},"    code_execution_config",[1158,2301,1424],{"class":1164},[1158,2303,1363],{"class":1168},[1158,2305,2306],{"class":1341},"\"work_dir\"",[1158,2308,2188],{"class":1168},[1158,2310,2311],{"class":1341},"\"workspace\"",[1158,2313,2193],{"class":1168},[1158,2315,2316],{"class":1160,"line":1404},[1158,2317,1653],{"class":1168},[1158,2319,2320],{"class":1160,"line":1410},[1158,2321,1257],{"emptyLinePlaceholder":1256},[1158,2323,2324],{"class":1160,"line":1418},[1158,2325,2326],{"class":1263},"# 创建群聊\n",[1158,2328,2329,2332,2334],{"class":1160,"line":1433},[1158,2330,2331],{"class":1168},"group_chat ",[1158,2333,1424],{"class":1164},[1158,2335,2336],{"class":1168}," GroupChat(\n",[1158,2338,2339,2342,2344],{"class":1160,"line":1454},[1158,2340,2341],{"class":1521},"    agents",[1158,2343,1424],{"class":1164},[1158,2345,2346],{"class":1168},"[user_proxy, coder, reviewer],\n",[1158,2348,2349,2352,2354],{"class":1160,"line":1469},[1158,2350,2351],{"class":1521},"    messages",[1158,2353,1424],{"class":1164},[1158,2355,2356],{"class":1168},"[],\n",[1158,2358,2359,2362,2364],{"class":1160,"line":1488},[1158,2360,2361],{"class":1521},"    max_round",[1158,2363,1424],{"class":1164},[1158,2365,2366],{"class":1191},"10\n",[1158,2368,2369],{"class":1160,"line":1493},[1158,2370,1653],{"class":1168},[1158,2372,2373],{"class":1160,"line":1499},[1158,2374,1257],{"emptyLinePlaceholder":1256},[1158,2376,2377,2380,2382,2385,2388,2390],{"class":1160,"line":1510},[1158,2378,2379],{"class":1168},"manager ",[1158,2381,1424],{"class":1164},[1158,2383,2384],{"class":1168}," GroupChatManager(",[1158,2386,2387],{"class":1521},"groupchat",[1158,2389,1424],{"class":1164},[1158,2391,2392],{"class":1168},"group_chat)\n",[1158,2394,2395],{"class":1160,"line":1533},[1158,2396,1257],{"emptyLinePlaceholder":1256},[1158,2398,2399],{"class":1160,"line":1538},[1158,2400,2401],{"class":1263},"# 发起任务\n",[1158,2403,2404],{"class":1160,"line":1544},[1158,2405,2406],{"class":1168},"user_proxy.initiate_chat(\n",[1158,2408,2409],{"class":1160,"line":1555},[1158,2410,2411],{"class":1168},"    manager,\n",[1158,2413,2414,2417,2419],{"class":1160,"line":1572},[1158,2415,2416],{"class":1521},"    message",[1158,2418,1424],{"class":1164},[1158,2420,2421],{"class":1341},"\"编写一个 Python 脚本来分析 CSV 文件中的销售数据并生成图表\"\n",[1158,2423,2424],{"class":1160,"line":1585},[1158,2425,1653],{"class":1168},[1043,2427,2429],{"id":2428},"autogen-适用场景","AutoGen 适用场景",[1057,2431,2432,2435,2438],{},[1060,2433,2434],{},"需要多个\"角色\"协作的复杂任务",[1060,2436,2437],{},"代码生成 + 执行 + 审查的迭代流程",[1060,2439,2440],{},"模拟真实团队的工作流程",[892,2442,1001],{"id":2443},"crewai",[896,2445,2446,2447,2450],{},"CrewAI 专注于",[936,2448,2449],{},"角色扮演式","的多 Agent 协作，灵感来源于真实团队的分工模式。",[1043,2452,1054],{"id":2453},"核心概念-1",[1057,2455,2456,2462,2468,2474],{},[1060,2457,2458,2461],{},[936,2459,2460],{},"Agent","：具有特定角色、目标和背景的智能体",[1060,2463,2464,2467],{},[936,2465,2466],{},"Task","：具体的任务定义，包含描述和期望输出",[1060,2469,2470,2473],{},[936,2471,2472],{},"Crew","：Agent 团队，定义协作流程",[1060,2475,2476,2479],{},[936,2477,2478],{},"Process","：任务执行模式（顺序或层级）",[1102,2481,2483],{"className":1152,"code":2482,"language":1154,"meta":11,"style":11},"from crewai import Agent, Task, Crew, Process\n\n# 定义 Agent 角色\nresearcher = Agent(\n    role=\"高级研究员\",\n    goal=\"深入研究给定主题并提供详尽的分析报告\",\n    backstory=\"你是一位经验丰富的技术研究员，擅长信息收集和分析\",\n    tools=[search_tool],\n    verbose=True\n)\n\nwriter = Agent(\n    role=\"技术写作专家\",\n    goal=\"将研究结果转化为通俗易懂的技术文章\",\n    backstory=\"你是一位资深技术作家，擅长用简洁的语言解释复杂概念\",\n    verbose=True\n)\n\n# 定义任务\nresearch_task = Task(\n    description=\"研究 AI Agent 在企业落地中的最佳实践\",\n    expected_output=\"一份包含关键发现、案例分析和趋势预测的研究报告\",\n    agent=researcher\n)\n\nwriting_task = Task(\n    description=\"基于研究报告撰写一篇技术博客文章\",\n    expected_output=\"一篇 2000 字左右的技术博客，结构清晰，案例丰富\",\n    agent=writer\n)\n\n# 组建团队\ncrew = Crew(\n    agents=[researcher, writer],\n    tasks=[research_task, writing_task],\n    process=Process.sequential,  # 顺序执行\n    verbose=True\n)\n\nresult = crew.kickoff()\n",[1110,2484,2485,2497,2501,2506,2516,2528,2540,2552,2561,2569,2573,2577,2586,2597,2608,2619,2627,2631,2635,2640,2650,2661,2673,2683,2687,2691,2700,2711,2722,2731,2735,2739,2744,2754,2763,2773,2786,2794,2798,2802],{"__ignoreMap":11},[1158,2486,2487,2489,2492,2494],{"class":1160,"line":1161},[1158,2488,1165],{"class":1164},[1158,2490,2491],{"class":1168}," crewai ",[1158,2493,1172],{"class":1164},[1158,2495,2496],{"class":1168}," Agent, Task, Crew, Process\n",[1158,2498,2499],{"class":1160,"line":1178},[1158,2500,1257],{"emptyLinePlaceholder":1256},[1158,2502,2503],{"class":1160,"line":1201},[1158,2504,2505],{"class":1263},"# 定义 Agent 角色\n",[1158,2507,2508,2511,2513],{"class":1160,"line":1214},[1158,2509,2510],{"class":1168},"researcher ",[1158,2512,1424],{"class":1164},[1158,2514,2515],{"class":1168}," Agent(\n",[1158,2517,2518,2521,2523,2526],{"class":1160,"line":1227},[1158,2519,2520],{"class":1521},"    role",[1158,2522,1424],{"class":1164},[1158,2524,2525],{"class":1341},"\"高级研究员\"",[1158,2527,1891],{"class":1168},[1158,2529,2530,2533,2535,2538],{"class":1160,"line":1240},[1158,2531,2532],{"class":1521},"    goal",[1158,2534,1424],{"class":1164},[1158,2536,2537],{"class":1341},"\"深入研究给定主题并提供详尽的分析报告\"",[1158,2539,1891],{"class":1168},[1158,2541,2542,2545,2547,2550],{"class":1160,"line":1253},[1158,2543,2544],{"class":1521},"    backstory",[1158,2546,1424],{"class":1164},[1158,2548,2549],{"class":1341},"\"你是一位经验丰富的技术研究员，擅长信息收集和分析\"",[1158,2551,1891],{"class":1168},[1158,2553,2554,2556,2558],{"class":1160,"line":1260},[1158,2555,2016],{"class":1521},[1158,2557,1424],{"class":1164},[1158,2559,2560],{"class":1168},"[search_tool],\n",[1158,2562,2563,2565,2567],{"class":1160,"line":1267},[1158,2564,2045],{"class":1521},[1158,2566,1424],{"class":1164},[1158,2568,2050],{"class":1191},[1158,2570,2571],{"class":1160,"line":1286},[1158,2572,1653],{"class":1168},[1158,2574,2575],{"class":1160,"line":1298},[1158,2576,1257],{"emptyLinePlaceholder":1256},[1158,2578,2579,2582,2584],{"class":1160,"line":1303},[1158,2580,2581],{"class":1168},"writer ",[1158,2583,1424],{"class":1164},[1158,2585,2515],{"class":1168},[1158,2587,2588,2590,2592,2595],{"class":1160,"line":1309},[1158,2589,2520],{"class":1521},[1158,2591,1424],{"class":1164},[1158,2593,2594],{"class":1341},"\"技术写作专家\"",[1158,2596,1891],{"class":1168},[1158,2598,2599,2601,2603,2606],{"class":1160,"line":1315},[1158,2600,2532],{"class":1521},[1158,2602,1424],{"class":1164},[1158,2604,2605],{"class":1341},"\"将研究结果转化为通俗易懂的技术文章\"",[1158,2607,1891],{"class":1168},[1158,2609,2610,2612,2614,2617],{"class":1160,"line":1338},[1158,2611,2544],{"class":1521},[1158,2613,1424],{"class":1164},[1158,2615,2616],{"class":1341},"\"你是一位资深技术作家，擅长用简洁的语言解释复杂概念\"",[1158,2618,1891],{"class":1168},[1158,2620,2621,2623,2625],{"class":1160,"line":1345},[1158,2622,2045],{"class":1521},[1158,2624,1424],{"class":1164},[1158,2626,2050],{"class":1191},[1158,2628,2629],{"class":1160,"line":1351},[1158,2630,1653],{"class":1168},[1158,2632,2633],{"class":1160,"line":1375},[1158,2634,1257],{"emptyLinePlaceholder":1256},[1158,2636,2637],{"class":1160,"line":1380},[1158,2638,2639],{"class":1263},"# 定义任务\n",[1158,2641,2642,2645,2647],{"class":1160,"line":1385},[1158,2643,2644],{"class":1168},"research_task ",[1158,2646,1424],{"class":1164},[1158,2648,2649],{"class":1168}," Task(\n",[1158,2651,2652,2654,2656,2659],{"class":1160,"line":1404},[1158,2653,1896],{"class":1521},[1158,2655,1424],{"class":1164},[1158,2657,2658],{"class":1341},"\"研究 AI Agent 在企业落地中的最佳实践\"",[1158,2660,1891],{"class":1168},[1158,2662,2663,2666,2668,2671],{"class":1160,"line":1410},[1158,2664,2665],{"class":1521},"    expected_output",[1158,2667,1424],{"class":1164},[1158,2669,2670],{"class":1341},"\"一份包含关键发现、案例分析和趋势预测的研究报告\"",[1158,2672,1891],{"class":1168},[1158,2674,2675,2678,2680],{"class":1160,"line":1418},[1158,2676,2677],{"class":1521},"    agent",[1158,2679,1424],{"class":1164},[1158,2681,2682],{"class":1168},"researcher\n",[1158,2684,2685],{"class":1160,"line":1433},[1158,2686,1653],{"class":1168},[1158,2688,2689],{"class":1160,"line":1454},[1158,2690,1257],{"emptyLinePlaceholder":1256},[1158,2692,2693,2696,2698],{"class":1160,"line":1469},[1158,2694,2695],{"class":1168},"writing_task ",[1158,2697,1424],{"class":1164},[1158,2699,2649],{"class":1168},[1158,2701,2702,2704,2706,2709],{"class":1160,"line":1488},[1158,2703,1896],{"class":1521},[1158,2705,1424],{"class":1164},[1158,2707,2708],{"class":1341},"\"基于研究报告撰写一篇技术博客文章\"",[1158,2710,1891],{"class":1168},[1158,2712,2713,2715,2717,2720],{"class":1160,"line":1493},[1158,2714,2665],{"class":1521},[1158,2716,1424],{"class":1164},[1158,2718,2719],{"class":1341},"\"一篇 2000 字左右的技术博客，结构清晰，案例丰富\"",[1158,2721,1891],{"class":1168},[1158,2723,2724,2726,2728],{"class":1160,"line":1499},[1158,2725,2677],{"class":1521},[1158,2727,1424],{"class":1164},[1158,2729,2730],{"class":1168},"writer\n",[1158,2732,2733],{"class":1160,"line":1510},[1158,2734,1653],{"class":1168},[1158,2736,2737],{"class":1160,"line":1533},[1158,2738,1257],{"emptyLinePlaceholder":1256},[1158,2740,2741],{"class":1160,"line":1538},[1158,2742,2743],{"class":1263},"# 组建团队\n",[1158,2745,2746,2749,2751],{"class":1160,"line":1544},[1158,2747,2748],{"class":1168},"crew ",[1158,2750,1424],{"class":1164},[1158,2752,2753],{"class":1168}," Crew(\n",[1158,2755,2756,2758,2760],{"class":1160,"line":1555},[1158,2757,2341],{"class":1521},[1158,2759,1424],{"class":1164},[1158,2761,2762],{"class":1168},"[researcher, writer],\n",[1158,2764,2765,2768,2770],{"class":1160,"line":1572},[1158,2766,2767],{"class":1521},"    tasks",[1158,2769,1424],{"class":1164},[1158,2771,2772],{"class":1168},"[research_task, writing_task],\n",[1158,2774,2775,2778,2780,2783],{"class":1160,"line":1585},[1158,2776,2777],{"class":1521},"    process",[1158,2779,1424],{"class":1164},[1158,2781,2782],{"class":1168},"Process.sequential,  ",[1158,2784,2785],{"class":1263},"# 顺序执行\n",[1158,2787,2788,2790,2792],{"class":1160,"line":1590},[1158,2789,2045],{"class":1521},[1158,2791,1424],{"class":1164},[1158,2793,2050],{"class":1191},[1158,2795,2796],{"class":1160,"line":1596},[1158,2797,1653],{"class":1168},[1158,2799,2800],{"class":1160,"line":1607},[1158,2801,1257],{"emptyLinePlaceholder":1256},[1158,2803,2804,2806,2808],{"class":1160,"line":1619},[1158,2805,1716],{"class":1168},[1158,2807,1424],{"class":1164},[1158,2809,2810],{"class":1168}," crew.kickoff()\n",[1772,2812,2813],{},"\nCrewAI 的最大优势是**直觉性**——用「角色」「任务」「团队」这些概念来组织 Agent 系统，对非技术背景的产品经理和业务人员也非常友好。\n",[892,2815,1023],{"id":2816},"dify",[896,2818,2819,2820,2823],{},"Dify 是一个开源的 LLM 应用开发平台，提供",[936,2821,2822],{},"可视化界面","来构建 Agent 和 AI 工作流。",[1043,2825,1788],{"id":2826},"核心特点-1",[1057,2828,2829,2835,2841,2847,2853],{},[1060,2830,2831,2834],{},[936,2832,2833],{},"可视化编排","：通过拖拽节点构建 Agent 工作流",[1060,2836,2837,2840],{},[936,2838,2839],{},"模型管理","：统一管理多个 LLM 提供商的模型",[1060,2842,2843,2846],{},[936,2844,2845],{},"知识库管理","：内置 RAG 流水线，支持多种文档格式",[1060,2848,2849,2852],{},[936,2850,2851],{},"API 发布","：一键将 Agent 发布为 API 服务",[1060,2854,2855,2858],{},[936,2856,2857],{},"监控与日志","：内置运行日志和用量监控",[1102,2860,2863],{"className":2861,"code":2862,"language":1107,"meta":1108},[1105],"flowchart TD\n    subgraph Dify[\"Dify 平台架构\"]\n        Chat[\"聊天助手\"]\n        Agent[\"Agent 模式\"]\n        Flow[\"工作流编排\"]\n        Model[\"模型提供商管理\u003Cbr\u002F>OpenAI\u002FAnthropic\u003Cbr\u002F>本地模型\u002F其他\"]\n        KB[\"知识库 \u002F 工具\"]\n        Chat --> Model\n        Agent --> Model\n        Flow --> Model\n        Model --> KB\n    end\n",[1110,2864,2862],{"__ignoreMap":11},[1091,2866,2867],{},"\nDify 适合**快速原型验证**和**非开发人员构建 AI 应用**。但对于需要高度定制化的复杂 Agent 系统，代码框架（如 LangGraph）仍然是更灵活的选择。\n",[892,2869,2870],{"id":2870},"如何选择框架",[896,2872,2873],{},"选择 Agent 框架需要根据具体场景和团队情况来判断：",[1043,2875,2876],{"id":2876},"决策指南",[1102,2878,2881],{"className":2879,"code":2880,"language":1107,"meta":1108},[1105],"flowchart TD\n    Q[\"你的核心需求是什么？\"]\n    Q --> A[\"快速原型验证\u003Cbr\u002F>非开发者使用\"] --> Dify[\"Dify\"]\n    Q --> B[\"数据查询和知识库 Agent\"] --> Llama[\"LlamaIndex\"]\n    Q --> C[\"多 Agent 协作\"]\n    C --> C1[\"需要灵活的对话模式\"] --> AutoGen[\"AutoGen\"]\n    C --> C2[\"需要角色化团队协作\"] --> CrewAI[\"CrewAI\"]\n    Q --> D[\"通用 Agent 开发\u003Cbr\u002F>#40;推荐默认选择#41;\"] --> LangGraph[\"LangGraph\"]\n",[1110,2882,2880],{"__ignoreMap":11},[1043,2884,2885],{"id":2885},"详细对比",[900,2887,2888,2901],{},[903,2889,2890],{},[906,2891,2892,2895,2898],{},[909,2893,2894],{},"考虑因素",[909,2896,2897],{},"推荐框架",[909,2899,2900],{},"原因",[928,2902,2903,2916,2928,2941,2953,2965],{},[906,2904,2905,2910,2913],{},[933,2906,2907],{},[936,2908,2909],{},"生产级应用",[933,2911,2912],{},"LangGraph",[933,2914,2915],{},"状态管理完善，可控性强",[906,2917,2918,2923,2925],{},[933,2919,2920],{},[936,2921,2922],{},"RAG 密集场景",[933,2924,960],{},[933,2926,2927],{},"数据连接和索引能力最强",[906,2929,2930,2935,2938],{},[933,2931,2932],{},[936,2933,2934],{},"快速搭建",[933,2936,2937],{},"Dify \u002F CrewAI",[933,2939,2940],{},"上手成本低",[906,2942,2943,2948,2950],{},[933,2944,2945],{},[936,2946,2947],{},"代码生成场景",[933,2949,980],{},[933,2951,2952],{},"内置代码执行环境",[906,2954,2955,2960,2962],{},[933,2956,2957],{},[936,2958,2959],{},"企业私有部署",[933,2961,1023],{},[933,2963,2964],{},"开源，支持私有化",[906,2966,2967,2972,2974],{},[933,2968,2969],{},[936,2970,2971],{},"最大灵活性",[933,2973,2912],{},[933,2975,2976],{},"图编排支持任意工作流",[2978,2979,2980],"warning",{},"\n框架发展非常快，API 变化频繁。建议始终参考各框架的**官方文档**获取最新用法。此外，不要过度依赖框架的高层抽象——理解底层原理（LLM 调用、工具调用、状态管理）才能在遇到问题时有效调试。\n",[892,2982,2983],{"id":2983},"小结",[896,2985,2986,2987,2989],{},"当前 Agent 框架生态百花齐放，各有侧重。对于大多数开发者，建议从 ",[936,2988,2912],{}," 入手——它提供了足够的灵活性和最活跃的社区支持。在后续章节中，我们将深入讲解工具调用机制，并使用 LangGraph 从零构建一个完整的 AI Agent 实战项目。",[2991,2992,2993],"style",{},"html pre.shiki code .s8jYJ, html code.shiki .s8jYJ{--shiki-light:#D73A49;--shiki-default:#D73A49;--shiki-dark:#F97583}html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}html pre.shiki code .sIIMD, html code.shiki .sIIMD{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#9ECBFF}html pre.shiki code .sP4rz, html code.shiki .sP4rz{--shiki-light:#E36209;--shiki-default:#E36209;--shiki-dark:#FFAB70}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}",{"title":11,"searchDepth":1178,"depth":1178,"links":2995},[2996,2997,3002,3005,3009,3012,3015,3019],{"id":894,"depth":1178,"text":894},{"id":1040,"depth":1178,"text":1041,"children":2998},[2999,3000,3001],{"id":1045,"depth":1201,"text":1046},{"id":1096,"depth":1201,"text":1097},{"id":1145,"depth":1201,"text":1146},{"id":1777,"depth":1178,"text":1778,"children":3003},[3004],{"id":1788,"depth":1201,"text":1788},{"id":2079,"depth":1178,"text":980,"children":3006},[3007,3008],{"id":1054,"depth":1201,"text":1054},{"id":2428,"depth":1201,"text":2429},{"id":2443,"depth":1178,"text":1001,"children":3010},[3011],{"id":2453,"depth":1201,"text":1054},{"id":2816,"depth":1178,"text":1023,"children":3013},[3014],{"id":2826,"depth":1201,"text":1788},{"id":2870,"depth":1178,"text":2870,"children":3016},[3017,3018],{"id":2876,"depth":1201,"text":2876},{"id":2885,"depth":1201,"text":2885},{"id":2983,"depth":1178,"text":2983},"md",{},{"title":14,"description":15},"ai\u002Fagent\u002Fframeworks","S0PK1i5qUq0pwcd1lMi1SLaQtI-7UzrNf0Zpe3gQ_to",1775474635619]