news 2026/5/14 2:26:59

.NET+AI | Agent | 中间件执行次序剖析(12)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
.NET+AI | Agent | 中间件执行次序剖析(12)


MAF 中间件执行顺序:深入理解洋葱模型

一句话简介

MAF 中间件遵循"洋葱模型"执行,请求从外向内,响应从内向外,正确理解执行顺序是构建企业级 Agent 的关键。


🎯 核心价值

  • 洋葱模型:请求依次经过外层→内层,响应按相反顺序返回

  • 三层触发频率:Agent Run 1次、ChatClient N次、Function M次

  • 精确时序:通过时间戳追踪完整执行链路


📝 执行顺序详解

触发次数对比

中间件层

触发时机

单次 Agent 调用触发次数

Agent RunRunAsync()1 次
ChatClient

每次 LLM 调用

2-N 次

(工具调用会增加)

Function

每次工具调用

0-M 次

(取决于工具数量)


💻 时序验证示例

带时间戳的中间件

var startTime = DateTime.UtcNow; double GetTimestamp() => (DateTime.UtcNow - startTime).TotalMilliseconds; // Agent Run 中间件 .Use(async (messages, thread, options, inner, ct) => { Console.WriteLine($"[T+{GetTimestamp():F0}ms] 🛡️ Agent Run Pre"); var response = await inner.RunAsync(messages, thread, options, ct); Console.WriteLine($"[T+{GetTimestamp():F0}ms] 🛡️ Agent Run Post"); return response; }, null)

典型输出

[T+0ms] 🛡️ Agent Run Pre [T+50ms] 📊 ChatClient Pre (第1次) [T+1200ms] 📊 ChatClient Post (第1次) [T+1210ms] 🔧 Function Pre: GetWeather [T+1320ms] 🔧 Function Post: GetWeather [T+1330ms] 📊 ChatClient Pre (第2次) [T+2500ms] 📊 ChatClient Post (第2次) [T+2510ms] 🛡️ Agent Run Post

📊 触发次数统计

场景:调用 2 个工具

Agent Run 中间件: 1 次 ChatClient 中间件: 2 次(初始调用 + 工具结果后调用) Function 中间件: 2 次(每个工具各 1 次)

计数器验证代码

var agentRunCount = 0; var chatClientCount = 0; var functionCount = 0; // 统计后输出 Console.WriteLine($"Agent Run: {agentRunCount} 次"); Console.WriteLine($"ChatClient: {chatClientCount} 次"); Console.WriteLine($"Function: {functionCount} 次");

🏢 企业级最佳实践

中间件注册顺序

注册顺序

执行顺序

推荐中间件

1️⃣ 最先注册

最外层

日志、监控

2️⃣ 中间注册

中间层

安全、限流

3️⃣ 最后注册

最内层

缓存、重试

注册顺序示例

var agent = chatClient.CreateAIAgent(...) .AsBuilder() .Use(LoggingMiddleware) // 最先注册 → 最外层 .Use(SecurityMiddleware) // 中间注册 → 中间层 .Use(CachingMiddleware) // 最后注册 → 最内层 .Build();

执行顺序:

请求 → Logging → Security → Caching → AI模型 响应 ← Logging ← Security ← Caching ←

🎯 总结

  • 洋葱模型:请求从外向内穿透,响应从内向外返回

  • 触发频率:Agent Run 1次,ChatClient/Function 多次

  • 注册顺序:先注册 = 更外层 = 先执行 Pre、后执行 Post

  • 实践建议:日志最外层,缓存最内层


如需获取文章配套完整代码,可扫码咨询领取。👇

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/12 20:45:11

Linly-Talker支持中文优化:本土化语音合成效果惊艳

Linly-Talker 中文语音合成优化:让数字人真正“说人话” 在短视频当道、虚拟主播频出的今天,你有没有注意到——那些号称“AI生成”的数字人讲解视频,很多听起来还是像在念稿?生硬的语调、错乱的声调、多音字误读……尤其是中文场…

作者头像 李华
网站建设 2026/5/12 21:52:09

Linly-Talker与LangChain整合:增强上下文理解能力

Linly-Talker与LangChain整合:增强上下文理解能力 在虚拟主播能24小时带货、AI客服动辄处理百万级对话的今天,一个核心问题逐渐浮现:我们真的需要“会说话”的数字人,还是更需要“会思考”的数字人? 当前市面上大多数数…

作者头像 李华
网站建设 2026/5/9 9:17:26

40、掌握 Microsoft Project 2003 宏录制与编辑技巧

掌握 Microsoft Project 2003 宏录制与编辑技巧 在项目管理中,Microsoft Project 2003 是一款强大的工具。为了提高工作效率,我们可以利用其宏录制和编辑功能,自动化一些重复性的任务。下面将详细介绍如何录制和编辑宏,以实现项目计划的 HTML 格式发布。 宏录制基础 在 …

作者头像 李华
网站建设 2026/5/13 8:09:54

55、掌握 Microsoft Project 2003:项目管理的全面指南

掌握 Microsoft Project 2003:项目管理的全面指南 1. 项目管理入门 在项目管理中,Microsoft Project 2003 是一款强大的工具,能助力我们开发和展示项目计划,管理进度与资源,处理多任务依赖关系,跟踪进度和成本。 1.1 基础操作 数据处理 :可进行数据的复制粘贴、导出…

作者头像 李华
网站建设 2026/5/11 7:07:09

56、掌握 Microsoft Project 2003:全面指南

掌握 Microsoft Project 2003:全面指南 1. 入门与基础操作 Microsoft Project 2003 是一款强大的项目管理工具,可帮助用户制定和展示项目计划、管理进度和资源、处理多重依赖关系以及跟踪进度和成本。它有专业版和标准版,专业版具有协作菜单、企业自定义字段等功能,标准版…

作者头像 李华
网站建设 2026/5/12 15:56:54

DAY32函数专题 1:函数定义与参数

知识点回顾: 1.函数的定义 2.变量作用域:局部变量和全局变量 3.函数的参数类型:位置参数、默认参数、不定参数 传递参数的手段:关键词参数4. 5.传递参数的顺序:同时出现三种参数类型时

作者头像 李华