System.Diagnostics.PerformanceCounter 9.0.15

About

This package provides types that allow applications to interact with the Windows performance counters.

Windows allows you to examine how programs you run affect your computer's performance, both in real time and by collecting log data for later analysis. You can do this via the Windows Performance Monitor tool, which uses performance counters, among other features.

Windows performance counters provide a high-level abstraction layer that provides a consistent interface for collecting various kinds of system data such as CPU, memory, and disk usage. They can be included in the operating system or can be part of individual applications. Windows Performance Monitor requests the current value of performance counters at specifiedtime intervals.

System administrators often use performance counters to monitor systems for performance or behavior problems. Software developers often use performance counters to examine the resource usage of their programs.

Key Features

  • Can be used to read existing predefined or custom counters.
  • Can be used for publishing (writing) data to custom counters.
  • Can collect performance counters from the local machine or from a remote machine.

How to Use

using System;
using System.Collections.Generic;
using System.Diagnostics;

public class App
{
    public static void Main()
    {
        List<CounterSample> samples = [];

        // If the category does not exist, create the category and exit.
        // Performance counters should not be created and immediately used.
        // There is a latency time to enable the counters, they should be created
        // prior to executing the application that uses the counters.
        // Execute this sample a second time to use the category.
        if (SetupCategory())
        {
            return;
        }

        CollectSamples(samples);
        CalculateResults(samples);
    }

    private static bool SetupCategory()
    {
        if (PerformanceCounterCategory.Exists("AverageCounter64SampleCategory"))
        {
            Console.WriteLine("Category exists - AverageCounter64SampleCategory");
            return false;
        }

        CounterCreationDataCollection counterDataCollection = [];

        // Add the counter.
        CounterCreationData averageCount64 = new()
        {
            CounterType = PerformanceCounterType.AverageCount64,
            CounterName = "AverageCounter64Sample"
        };
        counterDataCollection.Add(averageCount64);

        // Add the base counter.
        CounterCreationData averageCount64Base = new()
        {
            CounterType = PerformanceCounterType.AverageBase,
            CounterName = "AverageCounter64SampleBase"
        };
        counterDataCollection.Add(averageCount64Base);

        // Create the category.
        PerformanceCounterCategory.Create("AverageCounter64SampleCategory",
            "Demonstrates usage of the AverageCounter64 performance counter type.",
            PerformanceCounterCategoryType.SingleInstance, counterDataCollection);

        return true;
    }

    private static void CollectSamples(List<CounterSample> samples)
    {
        // Create the counters

        PerformanceCounter avgCounter64Sample = new PerformanceCounter("AverageCounter64SampleCategory",
            "AverageCounter64Sample",
            false)
        {
            RawValue = 0
        };

        PerformanceCounter avgCounter64SampleBase = new PerformanceCounter("AverageCounter64SampleCategory",
            "AverageCounter64SampleBase",
            false)
        {
            RawValue = 0
        };

        Random r = new(DateTime.Now.Millisecond);

        for (int j = 0; j < 100; j++)
        {
            int value = r.Next(1, 10);
            Console.Write(j + " = " + value);

            avgCounter64Sample.IncrementBy(value);

            avgCounter64SampleBase.Increment();

            if ((j % 10) == 9)
            {
                OutputSample(avgCounter64Sample.NextSample());
                samples.Add(avgCounter64Sample.NextSample());
            }
            else
            {
                Console.WriteLine();
            }

            System.Threading.Thread.Sleep(50);
        }
    }

    private static void CalculateResults(List<CounterSample> samples)
    {
        for (int i = 0; i < (samples.Count - 1); i++)
        {
            // Output the sample.
            OutputSample(samples[i]);
            OutputSample(samples[i + 1]);

            // Use .NET to calculate the counter value.
            Console.WriteLine($".NET computed counter value = {CounterSampleCalculator.ComputeCounterValue(samples[i], samples[i + 1])}");

            // Calculate the counter value manually.
            Console.WriteLine($"My computed counter value = {MyComputeCounterValue(samples[i], samples[i + 1])}");
        }
    }

    //    Description - This counter type shows how many items are processed, on average,
    //        during an operation. Counters of this type display a ratio of the items
    //        processed (such as bytes sent) to the number of operations completed. The
    //        ratio is calculated by comparing the number of items processed during the
    //        last interval to the number of operations completed during the last interval.
    // Generic type - Average
    //      Formula - (N1 - N0) / (D1 - D0), where the numerator (N) represents the number
    //        of items processed during the last sample interval and the denominator (D)
    //        represents the number of operations completed during the last two sample
    //        intervals.
    //    Average (Nx - N0) / (Dx - D0)
    //    Example PhysicalDisk\ Avg. Disk Bytes/Transfer
    private static float MyComputeCounterValue(CounterSample s0, CounterSample s1)
    {
        float numerator = (float)s1.RawValue - s0.RawValue;
        float denomenator = (float)s1.BaseValue - s0.BaseValue;
        float counterValue = numerator / denomenator;
        return counterValue;
    }

    private static void OutputSample(CounterSample s)
    {
        Console.WriteLine("\r\n+++++++++++");
        Console.WriteLine("Sample values - \r\n");
        Console.WriteLine($"   BaseValue        = {s.BaseValue}");
        Console.WriteLine($"   CounterFrequency = {s.CounterFrequency}");
        Console.WriteLine($"   CounterTimeStamp = {s.CounterTimeStamp}");
        Console.WriteLine($"   CounterType      = {s.CounterType}");
        Console.WriteLine($"   RawValue         = {s.RawValue}");
        Console.WriteLine($"   SystemFrequency  = {s.SystemFrequency}");
        Console.WriteLine($"   TimeStamp        = {s.TimeStamp}");
        Console.WriteLine($"   TimeStamp100nSec = {s.TimeStamp100nSec}");
        Console.WriteLine("++++++++++++++++++++++");
    }
}

Notes:

  • This assembly is only supported on Windows operating systems.
  • Only the administrator of the computer or users in the Performance Logs User Group can log counter data. Users in the Administrator group can log counter data only if the tool they use to log counter data is started from a Command Prompt window that is opened with Run as administrator.... Any users in interactive logon sessions can view counter data. However, users in non-interactive logon sessions must be in the Performance Monitoring Users group to view counter data.

Main Types

The main types provided by this library are:

Under the System.Diagnostics namespace, the main types are:

Under the System.Diagnostics.PerformanceData namespace, the main types are:

Additional Documentation

Feedback & Contributing

System.Diagnostics.PerformanceCounter is released as open source under the MIT license. Bug reports and contributions are welcome at the GitHub repository.

Showing the top 20 packages that depend on System.Diagnostics.PerformanceCounter.

Packages Downloads
Microsoft.ApplicationInsights.PerfCounterCollector
Application Insights Performance Counters Collector allows you to send data collected by Performance Counters to Application Insights. Privacy statement: https://go.microsoft.com/fwlink/?LinkId=512156
127
Microsoft.ApplicationInsights.PerfCounterCollector
Application Insights Performance Counters Collector allows you to send data collected by Performance Counters to Application Insights. Privacy statement: https://go.microsoft.com/fwlink/?LinkId=512156
132
Microsoft.ApplicationInsights.PerfCounterCollector
Application Insights Performance Counters Collector allows you to send data collected by Performance Counters to Application Insights. Privacy statement: https://go.microsoft.com/fwlink/?LinkId=512156
133
Microsoft.ApplicationInsights.PerfCounterCollector
Application Insights Performance Counters Collector allows you to send data collected by Performance Counters to Application Insights. Privacy statement: https://go.microsoft.com/fwlink/?LinkId=512156
135
Microsoft.ApplicationInsights.PerfCounterCollector
Application Insights Performance Counters Collector allows you to send data collected by Performance Counters to Application Insights. Privacy statement: https://go.microsoft.com/fwlink/?LinkId=512156
136
Microsoft.ApplicationInsights.PerfCounterCollector
Application Insights Performance Counters Collector allows you to send data collected by Performance Counters to Application Insights. Privacy statement: https://go.microsoft.com/fwlink/?LinkId=512156
137
Microsoft.ApplicationInsights.PerfCounterCollector
Application Insights Performance Counters Collector allows you to send data collected by Performance Counters to Application Insights. Privacy statement: https://go.microsoft.com/fwlink/?LinkId=512156
140
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
126
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
127
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
128
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
129
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
131
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
133
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
135
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
136
StackExchange.Redis
High performance Redis client, incorporating both synchronous and asynchronous usage.
146

https://go.microsoft.com/fwlink/?LinkID=799421

.NET Framework 4.6.2

  • No dependencies.

.NET 8.0

.NET 9.0

.NET Standard 2.0

  • No dependencies.

Version Downloads Last updated
11.0.0-preview.3.26207.106 4 04/14/2026
11.0.0-preview.2.26159.112 11 03/11/2026
11.0.0-preview.1.26104.118 16 02/11/2026
10.0.7 4 04/21/2026
10.0.6 9 04/14/2026
10.0.5 12 03/13/2026
10.0.4 13 03/11/2026
10.0.3 18 02/11/2026
10.0.2 22 01/13/2026
10.0.1 42 12/10/2025
10.0.0 55 11/12/2025
10.0.0-rc.2.25502.107 68 10/14/2025
10.0.0-rc.1.25451.107 84 09/09/2025
10.0.0-preview.7.25380.108 88 08/14/2025
10.0.0-preview.6.25358.103 75 07/17/2025
10.0.0-preview.5.25277.114 91 06/08/2025
10.0.0-preview.4.25258.110 74 05/15/2025
10.0.0-preview.3.25171.5 78 04/13/2025
10.0.0-preview.2.25163.2 92 04/01/2025
10.0.0-preview.1.25080.5 110 04/01/2025
9.0.15 4 04/14/2026
9.0.14 11 03/11/2026
9.0.13 16 02/11/2026
9.0.12 16 01/14/2026
9.0.11 50 11/12/2025
9.0.10 66 10/15/2025
9.0.9 88 09/09/2025
9.0.8 67 08/05/2025
9.0.7 98 07/09/2025
9.0.6 80 06/14/2025
9.0.5 82 05/16/2025
9.0.4 117 04/09/2025
9.0.3 93 03/30/2025
9.0.2 102 03/30/2025
9.0.1 114 03/30/2025
9.0.0 116 11/14/2024
9.0.0-rc.2.24473.5 103 10/21/2024
9.0.0-rc.1.24431.7 115 09/20/2024
9.0.0-preview.7.24405.7 100 08/20/2024
9.0.0-preview.6.24327.7 141 07/21/2024
9.0.0-preview.5.24306.7 117 07/21/2024
9.0.0-preview.4.24266.19 115 07/21/2024
9.0.0-preview.3.24172.9 150 07/21/2024
9.0.0-preview.2.24128.5 118 07/21/2024
9.0.0-preview.1.24080.9 127 07/21/2024
8.0.1 126 10/23/2024
8.0.0 129 07/21/2024
8.0.0-rc.2.23479.6 99 07/21/2024
8.0.0-rc.1.23419.4 121 07/21/2024
8.0.0-preview.7.23375.6 111 07/21/2024
8.0.0-preview.6.23329.7 107 07/21/2024
8.0.0-preview.5.23280.8 118 07/21/2024
8.0.0-preview.4.23259.5 123 07/21/2024
8.0.0-preview.3.23174.8 117 07/21/2024
8.0.0-preview.2.23128.3 120 07/21/2024
8.0.0-preview.1.23110.8 130 07/21/2024
7.0.0 116 07/21/2024
7.0.0-rc.2.22472.3 125 07/21/2024
7.0.0-rc.1.22426.10 121 07/21/2024
7.0.0-preview.7.22375.6 112 07/21/2024
7.0.0-preview.6.22324.4 116 07/21/2024
7.0.0-preview.5.22301.12 114 07/21/2024
7.0.0-preview.4.22229.4 110 07/21/2024
7.0.0-preview.3.22175.4 120 07/21/2024
7.0.0-preview.2.22152.2 101 07/21/2024
7.0.0-preview.1.22076.8 112 07/21/2024
6.0.2 90 11/14/2024
6.0.1 113 07/21/2024
6.0.0 112 07/21/2024
6.0.0-rc.2.21480.5 99 07/21/2024
6.0.0-rc.1.21451.13 123 07/21/2024
6.0.0-preview.7.21377.19 105 07/21/2024
6.0.0-preview.6.21352.12 112 07/21/2024
6.0.0-preview.5.21301.5 117 07/21/2024
6.0.0-preview.4.21253.7 134 07/21/2024
6.0.0-preview.3.21201.4 131 07/21/2024
6.0.0-preview.2.21154.6 112 07/21/2024
6.0.0-preview.1.21102.12 118 07/21/2024
5.0.1 108 07/21/2024
5.0.0 106 07/21/2024
5.0.0-rc.2.20475.5 132 07/21/2024
5.0.0-rc.1.20451.14 110 07/21/2024
5.0.0-preview.8.20407.11 99 07/21/2024
5.0.0-preview.7.20364.11 113 07/21/2024
5.0.0-preview.6.20305.6 118 07/21/2024
5.0.0-preview.5.20278.1 110 07/21/2024
5.0.0-preview.4.20251.6 127 07/21/2024
5.0.0-preview.3.20214.6 114 07/21/2024
5.0.0-preview.2.20160.6 126 07/21/2024
5.0.0-preview.1.20120.5 132 07/21/2024
4.7.0 113 07/21/2024
4.7.0-preview3.19551.4 111 07/21/2024
4.7.0-preview2.19523.17 110 07/21/2024
4.7.0-preview1.19504.10 115 07/21/2024
4.6.0 123 07/21/2024
4.6.0-rc1.19456.4 113 07/21/2024
4.6.0-preview9.19421.4 113 07/21/2024
4.6.0-preview9.19416.11 105 07/21/2024
4.6.0-preview8.19405.3 109 07/21/2024
4.6.0-preview7.19362.9 119 07/21/2024
4.6.0-preview6.19303.8 116 07/21/2024
4.6.0-preview6.19264.9 108 07/21/2024
4.6.0-preview5.19224.8 118 07/21/2024
4.6.0-preview4.19212.13 116 07/21/2024
4.6.0-preview3.19128.7 111 07/21/2024
4.6.0-preview.19073.11 111 07/21/2024
4.6.0-preview.18571.3 106 07/21/2024
4.5.0 101 07/21/2024
4.5.0-rc1 114 07/21/2024
4.5.0-preview2-26406-04 115 07/21/2024
4.5.0-preview1-26216-02 123 07/21/2024
4.5.0-preview1-25914-04 104 07/21/2024