news 2026/7/4 14:57:02

.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/7/4 4:59:36

Excalidraw监控指标采集:Prometheus+Grafana集成

Excalidraw监控指标采集:PrometheusGrafana集成 在现代协作型应用的运维实践中,一个看似“轻量”的工具往往承载着关键的团队协同价值。Excalidraw 作为一款广受欢迎的开源手绘风格白板工具,虽然架构简洁、部署方便,但一旦出现协作…

作者头像 李华
网站建设 2026/7/4 12:39:42

【自动驾驶基础】LDM(Latent Diffusion Model) 要点总结

LDM(Latent Diffusion Model) 要点总结 一、相关工作及劣势 (Related Work & Limitations) 1. 图像生成方法相关工作 1.1 自回归变换器 (Autoregressive Transformers) 代表性工作:包含数十亿参数的AR模型 [64, 65]特点:通过缩…

作者头像 李华
网站建设 2026/7/1 19:49:21

【FreeRTOS实战】互斥锁专题:从理论到STM32应用题

【FreeRTOS实战】互斥锁专题:解决优先级反转的利器,从理论到STM32应用 更详细的开发过程请参考【FreeRTOS实战】信号量专题:从底层原理到中断同步。 ✨ 本文亮点: 深入解析优先级反转问题的成因与危害对比互斥锁与二进制信号量的…

作者头像 李华
网站建设 2026/7/2 15:42:16

STM32学习——AD单通道AD多通道

1.AD单通道1.相关函数void RCC_ADCCLKConfig(uint32_t RCC_PCLK2);//用于配置 ADC(模数转换器)时钟源分频的核心函数,隶属于 RCC(复位和时钟控制)模块,作用是将 APB2 总线时钟(PCLK2&#xff09…

作者头像 李华
网站建设 2026/7/3 16:58:26

基于Spring Boot的农产品销售系统的设计与实现毕设源码

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于Spring Boot框架的农产品销售系统,以满足现代农业市场对高效、便捷、安全的农产品交易需求。具体研究目的如下&#xf…

作者头像 李华
网站建设 2026/7/3 10:17:57

基于Spring Boot的流浪动物救助平台的设计与实现毕业设计

博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于Spring Boot框架的流浪动物救助平台,以解决当前流浪动物救助工作中存在的问题,提高救助效率,优…

作者头像 李华