使用 C# 和 Blazor 开发的分布式压力测试框架DFrame

分布式压力测试框架

DFrame 是一个适用于 .NET 和 Unity 的分布式压力测试框架。

这个库允许您用纯 C# 代码编写分布式负载测试场景,不需要奇怪的 gui、dsl、xml、json、yaml。除了 HTTP/1 之外,您还可以通过用 C# 编写代码,来测试 HTTP/2、gRPC 等网络传输。.

使用 C# 和 Blazor 开发的分布式压力测试框架DFrame
怎么用?

DFrame 和 Locust 类似,由两部分组成, DFrame.Controller (由 Blazor Server 构建)作为 Web UI, DFrame.Worker 作为 C# 测试场景脚本。DFrame 作为 Nuget 库提供,如果您熟悉 C#,就可以轻松上手。

// Install-Package DFrame
using DFrame;

// WebUI:7312, WorkerListen:7313
DFrameApp.Run(7312, 7313); 

public class SampleWorkload : Workload
{
    public override async Task ExecuteAsync(WorkloadContext context)
    {
        Console.WriteLine($"Hello {context.WorkloadId}");
    }
}

现在您可以打开浏览器,访问 localhost:7312, 简单设置并进行测试。

使用 C# 和 Blazor 开发的分布式压力测试框架DFrame

您还可以设置参数,比如可以传入动态的 URL,可以在构造函数中接收参数。

using DFrame;
using Microsoft.Extensions.DependencyInjection;

var builder = DFrameApp.CreateBuilder(7312, 7313);
builder.ConfigureServices(services =>
{
    services.AddSingleton<HttpClient>();
});
await builder.RunAsync();

public class HttpGetString : Workload
{
    readonly HttpClient httpClient;
    readonly string url;

    // HttpClient 从 DI 获取
    // URL 从 Web UI 传入
    public HttpGetString(HttpClient httpClient, string url)
    {
        this.httpClient = httpClient;
        this.url = url;
    }

    public override async Task ExecuteAsync(WorkloadContext context)
    {
        await httpClient.GetStringAsync(url, context.CancellationToken);
    }
}
使用 C# 和 Blazor 开发的分布式压力测试框架DFrame

如果您只想简单的测试 HTTP GET/POST/PUT/DELETE,可以启用 IncludeDefaultHttpWorkload ,这样就可以传入 url 和 body 参数。

using DFrame;

var builder = DFrameApp.CreateBuilder(7312, 7313);
builder.ConfigureWorker(x =>
{
    x.IncludesDefaultHttpWorkload = true;
});
builder.Run();

DFrame 还支持在分布式场景中使用,对于每个 Worker,可以使用下面的代码,连接到统一的 Controller.

using DFrame;
using Microsoft.Extensions.Hosting;

await Host.CreateDefaultBuilder(args)
    .RunDFrameWorkerAsync("http://localhost:7313");  
测试模式

DFrame 有四种测试模式,可以根据需要自由配置。

Request 模式,可以设置总的执行次数,每个负载的并发数。

使用 C# 和 Blazor 开发的分布式压力测试框架DFrame

Repeat 重复模式,和 Ramp-Up 类似,并发数和请求数是逐步上升的。

使用 C# 和 Blazor 开发的分布式压力测试框架DFrame

Duration 可以对测试设置固定的时间。

使用 C# 和 Blazor 开发的分布式压力测试框架DFrame

Infinite 无穷的,持续执行,直到点击 STOP。

使用 C# 和 Blazor 开发的分布式压力测试框架DFrame
项目地址

https://github.com/Cysharp/DFrame