news 2026/4/23 16:11:40

.NET+AI | Agent | 自定义中间件(11)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
.NET+AI | Agent | 自定义中间件(11)

MAF 中间件管道架构:企业级 Agent 的三层拦截体系

一句话简介

MAF 提供三层中间件架构,分别拦截 ChatClient 调用、Agent 运行和工具调用,实现日志、限流、权限等企业级横切关注点。


🎯 核心价值

  • 三层拦截:ChatClient 层、Agent Run 层、Function Invocation 层

  • 职责分离:每层处理不同粒度的横切关注点

  • 灵活组合:可独立或组合使用,按需配置


📝 三层中间件架构

各层职责对比

层级

拦截时机

典型用途

触发频率

Agent RunRunAsync()

调用

PII 过滤、Guardrails

每次 Agent 调用 1 次

ChatClient

LLM 调用

Token 统计、限流、缓存

每次 LLM 调用(可能多次)

Function

工具执行

日志、权限检查、Mock

每次工具调用


💻 实现方式

1. ChatClient 中间件

使用 MEAI 的DelegatingChatClientUse()方法:

var chatClient = AIClientHelper.GetDefaultChatClient() .AsBuilder() .Use(getResponseFunc: async (messages, options, innerClient, ct) => { Console.WriteLine($"📊 [ChatClient] 请求消息数: {messages.Count()}"); var response = await innerClient.GetResponseAsync(messages, options, ct); Console.WriteLine($"📊 [ChatClient] Token: {response.Usage?.TotalTokenCount}"); return response; }) .Build();

核心要点:

  • 🔧 拦截每次 LLM 调用

  • 🔧 可访问完整的请求和响应

  • 🔧 适用于监控、限流、缓存等场景


2. Agent Run 中间件

使用AgentBuilder.Use()添加:

var agent = chatClient.CreateAIAgent(instructions: "你是智能助手") .AsBuilder() .Use(async (messages, thread, options, innerAgent, ct) => { Console.WriteLine($"🛡️ [Agent Run] Pre-Run 检查"); var response = await innerAgent.RunAsync(messages, thread, options, ct); Console.WriteLine($"🛡️ [Agent Run] Post-Run 完成"); return response; }, null) .Build();

核心要点:

  • 🛡️ 包裹整个 Agent 执行流程

  • 🛡️ 适用于安全检查、审计日志

  • 🛡️ 每次RunAsync()只触发一次


3. Function Invocation 中间件

拦截工具函数的执行:

var agent = chatClient.CreateAIAgent(...) .AsBuilder() .Use(async (agent, context, next, ct) => { Console.WriteLine($"🔧 [Function] 调用: {context.Function.Name}"); var result = await next(context, ct); Console.WriteLine($"🔧 [Function] 结果: {result}"); return result; }) .Build();

核心要点:

  • 🔧 拦截每个工具函数调用

  • 🔧 可修改参数或覆盖结果

  • 🔧 适用于权限检查、Mock 数据


🏢 企业级最佳实践

推荐的中间件组合

// 1️⃣ ChatClient 层:监控和性能 var chatClient = baseChatClient.AsBuilder() .Use(new TokenMonitoringMiddleware()) .Use(new RateLimitingMiddleware()) .Build(); // 2️⃣ Agent 层:安全和审计 var agent = chatClient.CreateAIAgent(...) .AsBuilder() .Use(PIIFilterMiddleware, null) // PII 过滤 .Use(GuardrailsMiddleware, null) // 内容安全 .Use(FunctionLoggingMiddleware) // 工具日志 .Build();

各层职责建议

层级

推荐用途

ChatClient

Token 统计、限流、缓存、重试

Agent Run

PII 过滤、Guardrails、全局审计

Function

权限检查、调用日志、Mock 数据


🎯 总结

  • 三层架构:ChatClient、Agent Run、Function Invocation 各司其职

  • 洋葱模型:请求从外向内,响应从内向外

  • 灵活组合:根据需求选择合适的中间件层级

  • 企业级应用:安全检查最外层,性能优化靠内层


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

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

Web服务器证书自动化管理终极指南:从零配置到企业级部署

Web服务器证书自动化管理终极指南:从零配置到企业级部署 【免费下载链接】caddy caddyserver/caddy: 是一个用于自动部署和配置 HTTPS 的服务器软件,可以用于快速部署静态网站和 Web 应用程序,支持 Let\s Encrypt 的免费 SSL 证书。 项目地…

作者头像 李华
网站建设 2026/4/23 14:50:20

5分钟掌握Dramatiq:Python分布式任务处理的终极方案

5分钟掌握Dramatiq:Python分布式任务处理的终极方案 【免费下载链接】dramatiq A fast and reliable background task processing library for Python 3. 项目地址: https://gitcode.com/gh_mirrors/dr/dramatiq 🚀 项目亮点速览 Dramatiq是一款…

作者头像 李华
网站建设 2026/4/23 11:41:59

Puppeteer-Sharp 终极指南:快速实现 .NET 浏览器自动化

Puppeteer-Sharp 终极指南:快速实现 .NET 浏览器自动化 【免费下载链接】puppeteer-sharp hardkoded/puppeteer-sharp: Puppeteer-Sharp 是 .NET 中的一个封装库,它提供了对 Google Chrome Puppeteer API 的访问,可用于爬虫抓取、网页自动化、…

作者头像 李华
网站建设 2026/4/23 11:43:19

3步搞定:从零搭建现代化CRM开发环境

3步搞定:从零搭建现代化CRM开发环境 【免费下载链接】twenty 构建一个由社区驱动的Salesforce的现代替代品。 项目地址: https://gitcode.com/GitHub_Trending/tw/twenty 还在为复杂的CRM系统本地部署而头疼吗?😫 作为Salesforce的现代…

作者头像 李华
网站建设 2026/4/22 22:09:09

FT232RL驱动程序完整安装指南:Windows 7/10系统终极解决方案

FT232RL驱动程序完整安装指南:Windows 7/10系统终极解决方案 【免费下载链接】FT232RLWin7Win10驱动程序 本仓库提供了适用于 Windows 7 和 Windows 10 操作系统的 FT232RL 驱动程序。FT232RL 是一款常用的 USB 转串口芯片,广泛应用于各种开发板和设备中…

作者头像 李华
网站建设 2026/4/23 11:40:37

基于VUE的开智慧农业项目管理平台[VUE]-计算机毕业设计源码+LW文档

摘要:智慧农业作为现代农业发展的重要方向,对项目管理提出了更高要求。本文介绍基于VUE的开智慧农业项目管理平台,阐述其开发背景与意义。平台运用VUE等技术,具备系统用户管理、新闻数据管理、项目列表管理等功能模块。通过需求分…

作者头像 李华