基于 .NET 的 AI 流式输出实现AgentFramework+SignalR

基于 .NET 的 AI 流式输出实现

技术栈选择

  • AgentFramework: 用于构建 AI 代理的框架,支持模块化设计和任务编排。
  • SignalR: 实现实时双向通信,支持 WebSocket 等协议,适合流式数据传输。

具体实现源码可参考NetCoreKevin的Kevin.SignalR+kevin.AI.AgentFramework模块

基于.NET构建的企业级SaaSAI智能体应用架构,采用前后端分离设计,具备以下核心特性:

前端技术:

实现步骤

服务端配置

安装必要的 NuGet 包:

bash 复制代码
dotnet add package Microsoft.AspNetCore.SignalR
dotnet add package Microsoft.AI.AgentFramework

创建 SignalR Hub 类:

csharp 复制代码
public class AiStreamingHub : Hub
{
    private readonly IAiAgent _aiAgent;

    public AiStreamingHub(IAiAgent aiAgent)
    {
        _aiAgent = aiAgent;
    }

    public async Task StreamResponse(string input)
    {
        var responseStream = _aiAgent.GetStreamingResponse(input);
        await foreach (var chunk in responseStream)
        {
            await Clients.Caller.SendAsync("ReceiveChunk", chunk);
        }
    }
}

AI 代理实现

创建支持流式输出的 AI 代理:

csharp 复制代码
public class StreamingAiAgent : IAiAgent
{
    public IAsyncEnumerable<string> GetStreamingResponse(string input)
    {
        return ProcessInputAsync(input);
    }

    private async IAsyncEnumerable<string> ProcessInputAsync(string input)
    {
        // 模拟 AI 处理过程
        var words = input.Split(' ');
        foreach (var word in words)
        {
            await Task.Delay(100); // 模拟处理延迟
            yield return word + " ";
        }
    }
}

客户端实现

JavaScript 客户端代码示例:

javascript 复制代码
const connection = new signalR.HubConnectionBuilder()
    .withUrl("/aiStreamingHub")
    .build();

connection.on("ReceiveChunk", (chunk) => {
    document.getElementById("output").innerHTML += chunk;
});

connection.start().then(() => {
    document.getElementById("sendButton").addEventListener("click", () => {
        const input = document.getElementById("input").value;
        connection.invoke("StreamResponse", input);
    });
});

配置和启动

在 Startup.cs 中配置服务:

csharp 复制代码
public void ConfigureServices(IServiceCollection services)
{
    services.AddSignalR();
    services.AddSingleton<IAiAgent, StreamingAiAgent>();
}

public void Configure(IApplicationBuilder app)
{
    app.UseRouting();
    app.UseEndpoints(endpoints =>
    {
        endpoints.MapHub<AiStreamingHub>("/aiStreamingHub");
    });
}

优化建议

性能优化

  • 设置适当的 SignalR 传输协议优先级
  • 实现 chunk 大小优化策略
  • 添加流控机制防止过载

错误处理

  • 实现重试机制
  • 添加超时控制
  • 完善客户端断开处理逻辑

扩展功能

  • 添加多客户端会话管理
  • 实现对话历史记录
  • 支持多模态数据流传输

测试验证

创建测试客户端验证功能:

csharp 复制代码
[Fact]
public async Task TestStreaming()
{
    var agent = new StreamingAiAgent();
    var output = new StringBuilder();
    
    await foreach (var chunk in agent.GetStreamingResponse("test input"))
    {
        output.Append(chunk);
    }
    
    Assert.Equal("test input ", output.ToString());
}

这种实现方式结合了 AgentFramework 的 AI 处理能力和 SignalR 的实时通信特性,可以构建高效的流式 AI 响应系统。

相关推荐
测试员周周6 小时前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
K姐研究社8 小时前
怎么用AI制作电商口播视频,开拍APP一键生成
人工智能·音视频
LaughingZhu9 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
传说故事9 小时前
【论文阅读】MotuBrain: An Advanced World Action Model for Robot Control
论文阅读·人工智能·具身智能·wam
魏杨杨9 小时前
一个程序员眼中的 AI 核心概念,讲透 LLM 、Agent 、MCP 、Skill 、RAG...
ai·.net·agent·claude code
北京耐用通信10 小时前
全域适配工业场景耐达讯自动化Modbus TCP 转 PROFIBUS 网关轻松实现以太网与现场总线互通
网络·人工智能·网络协议·自动化·信息与通信
火山引擎开发者社区10 小时前
TRAE × 火山引擎 Supabase:为你的 AI 应用装上“数据引擎”
人工智能
小a彤10 小时前
GE 在 CANN 五层架构中的位置
人工智能·深度学习·transformer
前端若水10 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Upsy-Daisy10 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习