news 2026/4/18 8:50:45

.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/4/1 7:32:56

49、掌握项目管理:从基础到实践

掌握项目管理:从基础到实践 在当今的商业环境中,有效的项目管理对于项目的成功至关重要。无论是小型项目还是大型企业级项目,都需要合理的规划、资源管理和进度跟踪。下面将详细介绍项目管理中的关键概念、操作方法以及基础理论。 项目管理工具与功能概述 项目管理工具在…

作者头像 李华
网站建设 2026/4/18 8:31:54

58、掌握 Microsoft Project 2003:项目管理全攻略

掌握 Microsoft Project 2003:项目管理全攻略 1. 项目管理基础 在项目管理中,Microsoft Project 2003 是一款强大的工具,它能帮助我们开发和展示项目计划、管理日程和资源、处理多重依赖关系,以及跟踪进度和成本。以下是使用它进行项目管理的基础步骤: - 创建任务列表…

作者头像 李华
网站建设 2026/4/16 19:54:48

50、使用 System Center Configuration Manager 管理 Windows Server 2016

使用 System Center Configuration Manager 管理 Windows Server 2016 在当今数字化的时代,高效管理服务器和设备对于企业的稳定运行至关重要。System Center Configuration Manager(SCCM,也称为 ConfigMgr)作为 Microsoft System Center 管理解决方案套件中的一员,为企业…

作者头像 李华
网站建设 2026/4/13 7:35:44

51、使用System Center Configuration Manager管理Windows Server 2016

使用System Center Configuration Manager管理Windows Server 2016 1. 安装System Center Configuration Manager 在安装过程中,需要完成一系列步骤: 1. 在站点系统角色中,保留默认选择以安装管理点和分发点角色。由于之前步骤中已选择,它们将使用HTTP作为默认客户端通信…

作者头像 李华
网站建设 2026/4/11 18:22:34

27、用户账户管理脚本的使用与故障排除

用户账户管理脚本的使用与故障排除 1. 脚本执行中的常见错误及解决方法 在执行用户账户管理脚本时,可能会出现多种错误。以下是一些常见错误及相应的解决办法: - 权限问题 :必须拥有在域或指定组织单位(OU)中创建新对象的权限。建议使用 /ou 参数指定目标 OU,而非…

作者头像 李华
网站建设 2026/4/15 17:42:50

4、深入解析微软虚拟化技术:从应用到管理

深入解析微软虚拟化技术:从应用到管理 在当今数字化时代,虚拟化技术对于企业的 IT 架构优化和资源利用效率提升起着至关重要的作用。微软提供了一系列丰富的虚拟化解决方案,涵盖了应用程序、桌面和服务器等多个层面。下面将详细介绍微软虚拟化技术的相关内容,包括应用和展…

作者头像 李华