news 2026/5/1 3:38:03

.NET+AI | Agent | 工具调用中间件对比(13)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
.NET+AI | Agent | 工具调用中间件对比(13)

MAF 与 MEAI 工具调用中间件集成

一句话简介

MEAI 的 UseFunctionInvocation 与 MAF 的 Function Middleware 是嵌套协作关系,前者负责自动化循环,后者负责业务控制。


🎯 核心价值

  • 嵌套协作:UseFunctionInvocation 在外层,MAF Middleware 在内层

  • 职责分离:MEAI 管自动化,MAF 管业务逻辑

  • 触发次数相等:FunctionInvoker 和 MAF Middleware 触发次数相同


📝 四层调用架构

各层职责对比

层级

位置

职责

典型用途

UseFunctionInvocation

ChatClient 层

自动化循环管理

迭代控制、并发调用

MEAI FunctionInvoker

ChatClient 内部

自定义调用前后逻辑

监控、预处理

MAF Function Middleware

Agent 层

业务逻辑控制

日志、权限、Mock


💻 执行链路

1. LLM 返回需要调用工具 GetWeather ↓ 2. 🔄 UseFunctionInvocation 检测到 FunctionCallContent ↓ 3. 📝 调用 FunctionInvoker(如果配置了) ↓ 4. 📝 FunctionInvoker 调用 context.Function.InvokeAsync() ↓ 5. 🔧 触发 MAF Function Middleware Pre-Invoke ↓ 6. ⚙️ 执行实际工具函数 GetWeather("北京") ↓ 7. 🔧 触发 MAF Function Middleware Post-Invoke ↓ 8. 📝 返回给 FunctionInvoker ↓ 9. 🔄 UseFunctionInvocation 将结果回传给 LLM

💻 配置示例

完整配置

// 1️⃣ ChatClient 层配置 var chatClient = baseChatClient .AsBuilder() .UseFunctionInvocation(configure: options => { options.AllowConcurrentInvocation = true; // 并发调用 options.MaximumIterationsPerRequest = 10; // 迭代控制 // 可选:自定义 FunctionInvoker options.FunctionInvoker = async (context, ct) => { Console.WriteLine($"📝 MEAI: 调用 {context.Function.Name}"); returnawait context.Function.InvokeAsync(context.Arguments, ct); }; }) .Build(); // 2️⃣ Agent 层配置 var agent = chatClient.CreateAIAgent(...) .AsBuilder() .Use(async (agent, context, next, ct) => { Console.WriteLine($"🔧 MAF: 调用 {context.Function.Name}"); returnawait next(context, ct); }) .Build();

🏢 最佳实践

职责分离原则

// ✅ 推荐:清晰的职责分离 .UseFunctionInvocation(configure: options => { // MEAI 层:只负责自动化控制 options.AllowConcurrentInvocation = true; options.MaximumIterationsPerRequest = 10; // 不配置 FunctionInvoker,让 MAF 层统一处理 }) .Use(async (agent, context, next, ct) => { // MAF 层:统一的企业级控制 ValidatePermission(context.Function.Name); // 权限检查 LogFunctionCall(context); // 审计日志 returnawait next(context, ct); })

避免重复拦截

// ❌ 避免:在两个地方做相同的事 .UseFunctionInvocation(options => { options.FunctionInvoker = async (ctx, ct) => { Console.WriteLine("MEAI: 日志记录"); // 重复! returnawait ctx.Function.InvokeAsync(...); }; }) .Use(async (agent, ctx, next, ct) => { Console.WriteLine("MAF: 日志记录"); // 重复! returnawait next(ctx, ct); })

使用场景选择

场景

推荐配置

简单 Agent

不使用 UseFunctionInvocation

需要并发调用

使用 UseFunctionInvocation

企业级控制

使用 MAF Function Middleware

两者结合

MEAI 自动化 + MAF 业务控制


🎯 总结

  • 嵌套关系:UseFunctionInvocation → FunctionInvoker → MAF Middleware → 工具

  • 触发次数:FunctionInvoker 触发次数 == MAF Middleware 触发次数

  • 职责分离:MEAI 负责自动化,MAF 负责业务逻辑

  • 最佳实践:不要在两层做重复的事,统一在 MAF 层处理


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

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

Excalidraw撤销重做层级限制:最多能回退几步?

Excalidraw撤销重做层级限制:最多能回退几步? 在数字白板工具日益成为团队协作核心载体的今天,一个看似不起眼的功能——“撤销”(Undo),却常常决定着用户是否愿意长期使用这款产品。尤其是在 Excalidraw 这…

作者头像 李华
网站建设 2026/4/13 0:33:59

管理的本质

管理本质可归纳为三点: 1、是对人的引领、对事的统筹和对资源的整合; 2、是洞察需求、整合力量以达成目标; 3、是将无序变为有序、低效变为高效,促使个体凝聚为整体。 这三句话系统概括了管理工作的核心逻辑——从资源整合到目标实…

作者头像 李华
网站建设 2026/4/29 19:06:49

如何更好地作为数据科学家进行沟通

原文:towardsdatascience.com/how-to-better-communicate-as-a-data-scientist-6fc5428d3143 https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/57303eba632bf29139041b123b635534.png 图片由作者提供 在我之前的文章中&#x…

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

水作业.2

用程序模拟一个活动的投票统计功能。首先输入参选人员个数,再输入每位参选人员名字(不超过20字节),再输入选票张数,再依次输入选票中所选的参选人名(选票中必须选参选中的其中一位)。在输入选票…

作者头像 李华
网站建设 2026/4/29 9:55:11

小批量硅胶复模,±0.1mm精度,比钢模具少40%,品质保障

小批量硅胶复模,0.1mm精度,比钢模具少40%,品质保障“小批量生产选硅胶复模还是钢模具?精度能不能达标?成本会不会超支?”最近后台收到不少制造业朋友的留言,核心诉求都围绕着小批量生产的模具选型难题。尤其是初创企业、产品研发团…

作者头像 李华
网站建设 2026/4/19 6:39:38

基于Spring Boot的旅游攻略平台的设计与实现毕业设计源码

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于Spring Boot框架的旅游攻略平台,以解决当前旅游信息获取与分享过程中存在的诸多问题。具体研究目的如下:提…

作者头像 李华