链载Ai

标题: 一文带你读懂 Google LangGraph 项目,快速入门 AI Agent 全栈开发 [打印本页]

作者: 链载Ai    时间: 2 小时前
标题: 一文带你读懂 Google LangGraph 项目,快速入门 AI Agent 全栈开发

ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;display: table;padding: 0.3em 1.2em;color: rgb(255, 255, 255);background: rgb(0, 152, 116);border-radius: 8px 24px;box-shadow: rgba(0, 0, 0, 0.06) 0px 2px 6px;">一、项目背景与目标

ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;font-size: 16px;letter-spacing: 0.1em;color: rgb(63, 63, 63);">最近在带着同事一起做智能 Agent 相关的内部项目,发现很多人对 LangGraph 非常感兴趣,但又不太清楚如何从零开始搭建一个完整的 AI Agent,我于是在 github 上找,看看有没有好的开源项目给他们学习,偶然间发现了 google-gemini 开源的这个项目[1],正好拿来给他们讲讲,学习学习。发现整理的材料又正好可以出一期公众号文章,就作为我公众号的一篇番外,来讲讲。

ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;font-size: 16px;font-style: italic;padding: 1em 1em 1em 2em;border-radius: 6px;color: rgba(0, 0, 0, 0.6);background: rgb(247, 247, 247);">
题外话:我十分不主张,一遇到新需求,就好像对应的知识就得全部掌握,得去花大力气看看基础教程,了解全貌之后,再开始行动。如果真是这样的话,这个项目大概率就得黄了。ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;font-size: inherit;color: rgb(0, 152, 116);">应该是要根据目标去找,去按需学习。
ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;font-size: 16px;color: rgb(63, 63, 63);">ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;font-size:16px;margin:0.1em auto 0.5em;border-radius:8px;width:100%;"/>

ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;font-size: 16px;letter-spacing: 0.1em;color: rgb(63, 63, 63);">你可能已经用过市面上的一些“低代码/零代码”智能体平台,比如 Coze、dify 这类产品。它们就像搭积木一样,让你拖拽组件、配置流程,快速拼出一个属于自己的 AI Agent。这种方式对于业务快速上线、简单场景非常友好。

ingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;font-size: 16px;letter-spacing: 0.1em;color: rgb(63, 63, 63);">但你有没有遇到过这样的问题:

这时候,你就需要跳出“应用端拼装”,进入“代码层级的自定义”。本项目就是为此而生——它不仅让你看到一个完整的“AI 研究员”是怎么从零到一搭建起来的,还能让你随时插拔、扩展、魔改每一个环节。

它适合:

核心亮点

在接下来的内容中,我会像一位带你实战的讲师,带你从全局到细节,逐步拆解这个项目的每一处关键实现。

二、项目组成与架构

在正式读代码前,我们先快速了解一下项目的整体结构和技术选型。

目录结构简述

技术栈

核心流程

  1. 1. 用户输入问题(网页或命令行)
  2. 2. 代理自动生成搜索词 → Google 搜索 → Gemini 总结 → 反思知识盲区 → 迭代补充 → 合成带引用的答案

你可以把它想象成一个“AI 研究员”,自动帮你查资料、归纳、补充、引用,最后给你一份有理有据的答案。

三、如何启动和体验项目


在动手读代码前,我们先来体验一下项目的实际效果。

1. 环境准备

2. 安装依赖

在项目根目录下:

setup.batinstall

或分别:

setup.bat install-backend
setup.bat install-frontend

3. 运行开发环境

setup.batdev

4. 命令行体验

setup.batcli-example"今天武汉的天气怎么样?"

你可以先随便问一个问题,感受一下“processing...”之后,AI 是如何给你一份带引用的研究报告的。

四、端到端代码导读

接下来,让我们像课堂实战一样,带着问题、带着好奇心,一步步走进项目的核心实现。

1. 入口:命令行调用

我们先从最简单的命令行入口开始。

文件backend/examples/cli_research.py

你可以打开这个文件,看到如下关键代码:

fromagent.graphimportgraph # 第3行
...
result = graph.invoke(state) # 第36行

这里的graph.invoke(state),就是整个“AI 研究员”流程的起点。你输入一个问题,所有的自动研究、搜索、推理、引用,都是从这里开始的。

小贴士:如果你想快速体验后端的效果,可以直接在命令行运行:

pythonbackend/examples/cli_research.py"今天武汉的天气怎么样?"

2. 跳转到核心代理定义

接下来,我们顺着from agent.graph import graph跳到核心代理的定义。

文件backend/src/agent/graph.py

你会看到一段类似“流程图”的代码:

builder.add_node("generate_query", generate_query)   # 第272行
builder.add_node("web_research", web_research) # 第273行
builder.add_node("reflection", reflection) # 第274行
builder.add_node("finalize_answer", finalize_answer) # 第275行
...
builder.add_edge(START,"generate_query") # 第279行
builder.add_conditional_edges("generate_query", continue_to_web_research, ["web_research"])# 第281行
builder.add_edge("web_research","reflection") # 第285行
builder.add_conditional_edges("reflection", evaluate_research, ["web_research","finalize_answer"])# 第287行
builder.add_edge("finalize_answer", END) # 第291行

林生点评

3. 节点实现详解

现在我们带着“AI 研究员”的视角,逐个节点来看它们都做了什么。

3.1.generate_query节点

llm = ChatGoogleGenerativeAI(...)
structured_llm = llm.with_structured_output(SearchQueryList)
formatted_prompt = query_writer_instructions.format(...)
result = structured_llm.invoke(formatted_prompt)
return{"search_query": result.query}

3.2.continue_to_web_research节点

return[
Send("web_research", {"search_query": search_query,"id":int(idx)})
foridx, search_queryinenumerate(state["search_query"])
]

3.3.web_research节点

response = genai_client.models.generate_content(...)
resolved_urls = resolve_urls(...)
citations = get_citations(response, resolved_urls)
modified_text = insert_citation_markers(response.text, citations)
sources_gathered = [itemforcitationincitationsforitemincitation["segments"]]
return{
"sources_gathered": sources_gathered,
"search_query": [state["search_query"]],
"web_research_result": [modified_text],
}

3.4.reflection节点

formatted_prompt = reflection_instructions.format(...)
llm = ChatGoogleGenerativeAI(...)
result = llm.with_structured_output(Reflection).invoke(formatted_prompt)
return{
"is_sufficient": result.is_sufficient,
"knowledge_gap": result.knowledge_gap,
"follow_up_queries": result.follow_up_queries,
...
}

3.5.evaluate_research节点

ifstate["is_sufficient"]orstate["research_loop_count"] >= max_research_loops:
return"finalize_answer"
else:
return[
Send("web_research", {...})
foridx, follow_up_queryinenumerate(state["follow_up_queries"])
]

3.6.finalize_answer节点

formatted_prompt = answer_instructions.format(...)
llm = ChatGoogleGenerativeAI(...)
result = llm.invoke(formatted_prompt)
# 替换短链为原始链接
forsourceinstate["sources_gathered"]:
ifsource["short_url"]inresult.content:
result.content = result.content.replace(
source["short_url"], source["value"]
)
unique_sources.append(source)
return{
"messages": [AIMessage(content=result.content)],
"sources_gathered": unique_sources,
}

4. 数据结构与工具定义

在读节点实现时,你可能会好奇:SearchQueryListReflection这些结构体是怎么定义的?

文件backend/src/agent/tools_and_schemas.py

你可以随时跳到这个文件,看看每个字段的含义和注释。

5. 总结跳转链路

到这里,我们已经带着“AI 研究员”的视角,完整走了一遍从命令行输入到最终答案输出的全链路。

  1. 1.入口cli_research.py第36行graph.invoke(state)
  2. 2.流程定义graph.py第269-291行(StateGraph 构建)
  3. 3.节点实现graph.py第36-265行(每个节点的具体逻辑)
  4. 4.数据结构tools_and_schemas.py(第5-24行)

你可以跟着这些跳转,边看边实验,体会每一步的数据流转和设计巧思。

6. 建议的学习方式

最后,给大家一些实战建议:


本文章可作为写作、讲解、二次开发的基础材料,欢迎补充和完善!希望你能像带着学员实战一样,真正掌握 LangGraph 应用开发的精髓。

原先的 google-gemini 该项目的地址如下,大家可以跳转去看:https://github.com/google-gemini/gemini-fullstack-langgraph-quickstart

我在这个项目的基础上进行了部分修改,有完整的中文使用教程,以及本地 Windows 部署脚本调整,方便大家直接运行和二次开发。如果对这块感兴趣,可以关注我的微信公众号,直接发消息“langgraph”,即可获得该项目的完整代码和使用教程。






欢迎光临 链载Ai (https://www.lianzai.com/) Powered by Discuz! X3.5