ASP.NET Core应用程序的CPU峰值/等待时间
创始人
2024-09-16 01:30:40
0

要获取ASP.NET Core应用程序的CPU峰值和等待时间,可以使用以下代码示例:

using System;
using System.Diagnostics;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;

public class Program
{
    public static async Task Main(string[] args)
    {
        var host = CreateHostBuilder(args).Build();

        // 启动性能计数器
        var process = Process.GetCurrentProcess();
        var cpuCounter = new PerformanceCounter("Processor", "% Processor Time", "_Total");
        var waitCounter = new PerformanceCounter("Processor", "% Idle Time", "_Total");

        // 启动计时器
        var stopwatch = Stopwatch.StartNew();

        try
        {
            // 启动ASP.NET Core应用程序
            await host.RunAsync();
        }
        finally
        {
            // 停止计时器
            stopwatch.Stop();

            // 停止性能计数器
            cpuCounter.Close();
            cpuCounter.Dispose();
            waitCounter.Close();
            waitCounter.Dispose();

            // 输出CPU峰值和等待时间
            var cpuPeak = cpuCounter.NextValue() / Environment.ProcessorCount;
            var cpuWait = waitCounter.NextValue() / Environment.ProcessorCount;
            Console.WriteLine($"CPU Peak: {cpuPeak}%");
            Console.WriteLine($"CPU Wait: {cpuWait}%");
            Console.WriteLine($"Elapsed Time: {stopwatch.Elapsed.TotalSeconds} seconds");
        }
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup();
            });
}

在上述代码中,我们使用了PerformanceCounter类来获取CPU的峰值和等待时间。我们在应用程序开始时启动计数器,并在应用程序结束时停止计数器。然后,我们使用NextValue方法获取当前的CPU使用率,并除以处理器数量来获取每个处理器的平均使用率。最后,我们使用Stopwatch类来计算应用程序的运行时间。

请注意,上述代码示例是在应用程序的Main方法中实现的。根据你的需求,你可以将这些代码放置在适当的位置,以便在应用程序的特定阶段或事件中获取CPU峰值和等待时间。

相关内容

热门资讯

透视辅助!微乐小程序黑科技,小... 透视辅助!微乐小程序黑科技,小程序微乐贵阳捉鸡麻将挂(透视)切实真的有挂(哔哩哔哩)1、小程序微乐贵...
9分钟下载!微乐小程序黑科技,... 9分钟下载!微乐小程序黑科技,提高微乐运气的方法(开挂)确实是有挂(2026)9分钟下载!微乐小程序...
透视工具!微乐小程序黑科技,微... 透视工具!微乐小程序黑科技,微乐贵阳捉鸡麻将辅助(透视)都是有挂(哔哩哔哩)1、首先打开微乐贵阳捉鸡...
一分钟开挂!微乐小程序黑科技,... 一分钟开挂!微乐小程序黑科技,微乐游戏竞技团辅助(开挂)其实是真的挂(2026)1、在微乐小程序黑科...
透视玄学!微乐小程序黑科技,微... 透视玄学!微乐小程序黑科技,微乐自建房怎么提高运气(透视)一直存在有挂(哔哩哔哩)1、这是跨平台的微...
第3分钟脚本!微乐小程序免费黑... 第3分钟脚本!微乐小程序免费黑科技,微信小程序微乐游戏辅助(开挂)一贯是真的挂(2026)1、首先打...
教学辅助挂!微乐小程序免费黑科... 教学辅助挂!微乐小程序免费黑科技,2025微乐小程序黑科技(透视)本来是真的挂(哔哩哔哩)微乐小程序...
第3分钟神器!微乐小程序黑科技... 第3分钟神器!微乐小程序黑科技,微乐自建房插件如何安装(开挂)竟然真的有挂(2026)1.微乐小程序...
第三方辅助挂!微乐小程序黑科技... 第三方辅助挂!微乐小程序黑科技,微乐自建房辅助入口官网(透视)一直是真的挂(哔哩哔哩)1、全新机制【...
4分钟开挂!微乐小程序黑科技,... 4分钟开挂!微乐小程序黑科技,微乐小程序透视工具(开挂)原来有挂(2026);1、首先打开微乐小程序...