Чтение онлайн

ЖАНРЫ

C# для профессионалов. Том II

Ватсон Карли

Шрифт:

 // ...

Программа обработки

OnEntryWritten
получает объект
EntryWrittenEventArgs
в качестве аргумента, где можно получить всю информацию из события. С помощью свойства
Entry
мы получаем объект
EventLogEntry
с информацией о времени, источнике события, типе, категории и т. д.:

protected void OnEntryWritten(object sender, System.Diagnostics.EntryWrittenEventArgs e) {

 DateTime time = e.Entry.TimeGenerated;

 string message = e.Entry.Message;

 listBoxEvents.Items.Add(time + " " + message);

}

Выполняющееся

приложение показывает все события для
QuoteService
:

Мониторинг производительности

Мониторинг производительности может использоваться для получения информации о нормальном выполнении службы. Это прекрасный инструмент, который помогает понять нагрузку системы и наблюдать изменения и тенденции.

Windows 2000 имеет множество объектов производительности, таких как

System
,
Memory
,
Objects
,
Process
,
Processor
,
Thread
,
Cache
и т. д. Каждый из этих объектов имеет множество показателей для мониторинга. С помощью объекта Process для всех процессов или для определенных экземпляров процессов можно контролировать время пользователя, счетчик дескрипторов. Ошибки страниц, счетчик потоков выполнения и т. д. В некоторых приложениях также имеются специфические объекты, например SQL Server.

Для нашей службы цитат может представлять интерес получение информации о числе клиентских запросов, размере данных, посылаемых по каналам связи, и т.д.

Классы мониторинга производительности

Пространство имен

System.Diagnostics
имеет следующие классы для мониторинга производительности:

□ 

PerformanceCounter
используется как для мониторинга счетчиков, так и для записи счетчиков. С помощью этого класса можно создавать новые категории производительности.

□ С помощью класса

PerformanceCounterCategory
можно пройти через все существующие категории, а также создать новые. Программным путем получаются все счетчики категории.

□ Класс

PerformanceCounterInstaller
используется для установки счетчиков производительности, аналогично классу
EventLogInstaller
, о котором упоминалось ранее.

Построитель счетчиков производительности 

Можно создать новую категорию, выбирая счетчики производительности в Server Explorer. Категория называется

Quote Service
. В таблице показаны все счетчики производительности нашей службы:

Имя Описание Тип
# of Bytes sent Общее число байтов, посланных клиенту.
NumberOfItems32
# of Bytes sent/sec Число байтов, посылаемых клиенту в одну секунду.
NumberOfItems32
# of Requests Общее
число запросов.
NumberOfItems32
# of Requests /sec Число запросов в одну секунду.
NumberOfItems32

Построитель счетчика производительности записывает конфигурацию в базу данных производительности. Это может также делаться динамически с помощью метода

Create
класса
PerformanceCategory
в пространстве имен
System.Diagnostics
. Программу установки для других систем можно легко добавить в последующем с помощью Visual Studio.NET.

Построитель счетчика производительности запускается из Server Explorer при выборе контекстного меню Performance Counters|Create New Category:

Добавление счетчиков производительности

Теперь мы хотим добавить счетчики производительности в сервер цитат. Класс

QuoteServiсе
не располагает информацией, необходимой для счетчиков производительности. Мы хотим получить число запросов, но после запуска службы
QuoteService
не получает запросов. Информация полностью содержится в классе
QuoteServer
, созданном ранее.

Добавление поддержки Visual Studio.NET Designer в библиотеку классов

Можно вручную добавить в код экземпляры класса

PerformanceCounter
либо использовать приложение Visual Studio.NET Designer. С его помощью перетаскиваются компоненты
PerformanceCounter
из панели инструментов на его рабочую поверхность. Поддержку легко добавить в библиотеку компонентов, выводя класс из
System.ComponentModel.Component
. Метод
InitializeComponent
, который используется для задания свойств компонентов, будет исполняться автоматически, необходимо добавить лишь его вызов.

Добавление компонентов PerformanceCounter

Далее можно добавить компоненты

PerformanceCounter
из панели инструментов. Для нашей службы добавляется четыре экземпляра, где свойство
CategoryName
задается как Quote Service Count для всех объектов, а свойство
CounterName
задается одним из значений, доступным в выбранной категории. Свойство
ReadOnly
должно быть задано как
False
.

Код, который был внесен в

InitializeComponent
путем добавления
Components
в конструктор и заданием свойств, выглядит так:

private void InitializeComponent {

 // ...

 //

 // performanceCounterRequestsPerSec

 //

 this.performanceCounterRequestsPerSec.CategoryName =

"Quote Service Counts";

 this.performanceCounterRequestsPerSec.CounterName =

"# of Requests / sec";

 this.performanceCounterRequestsPerSec.ReadOnly = false;

Поделиться с друзьями: