Симон Робинсон - C# для профессионалов. Том II
- Название:C# для профессионалов. Том II
- Автор:
- Жанр:
- Издательство:Лори
- Год:2003
- Город:Москва
- ISBN:5-85582-187-0
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Симон Робинсон - C# для профессионалов. Том II краткое содержание
Платформа .NET предлагает новую среду, в которой можно разрабатывать практически любое приложение, действующее под управлением Windows, а язык C# — новый язык программирования, созданный специально для работы с .NET.
В этой книге представлены все основные концепции языка C# и платформы .NET. Полностью описывается синтаксис C#, приводятся примеры построения различных типов приложений с использованием C# — создание приложений и служб Windows, приложений и служб WWW при помощи ASP.NET, а также элементов управления Windows и WWW Рассматриваются общие библиотеки классов .NET, в частности, доступ к данным с помощью ADO.NET и доступ к службе Active Directory с применением классов DirectoryServices.
Для кого предназначена эта книгаЭта книга предназначена для опытных разработчиков, возможно, имеющих опыт программирования на VB, C++ или Java, но не использовавших ранее в своей работе язык C# и платформу .NET. Программистам, применяющим современные технологии, книга даст полное представление о том, как писать программы на C# для платформы .NET.
Основные темы книги• Все особенности языка C#
• C# и объектно-ориентированное программирование
• Приложения и службы Windows
• Создание web-страниц и web-служб с помощью ASP NET
• Сборки .NET
• Доступ к данным при помощи ADO NET
• Создание распределённых приложений с помощью NET Remoting
• Интеграция с COM, COM+ и службой Active Directory
C# для профессионалов. Том II - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Пространство имен 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
, созданном ранее.
Можно вручную добавить в код экземпляры класса PerformanceCounter
либо использовать приложение Visual Studio.NET Designer. С его помощью перетаскиваются компоненты PerformanceCounter
из панели инструментов на его рабочую поверхность. Поддержку легко добавить в библиотеку компонентов, выводя класс из System.ComponentModel.Component
. Метод InitializeComponent()
, который используется для задания свойств компонентов, будет исполняться автоматически, необходимо добавить лишь его вызов.
Далее можно добавить компоненты 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;
//
// performanceCounterBytesSentTotal
//
this.performanceCounterBytesSentTotal.CategoryName =
"Quote Service Counts";
this.performanceCounterBytesSentTotal.CounterName =
"# of Bytes sent";
this.performanceCounterBytesSentTotal.ReadOnly = false;
//
// performanceCounterBytesSentPerSec
//
this.performanceCounterBytesSentPerSec.CategoryName =
"Quote Service Counts";
this.performanceCounterBytesSentPerSec.CounterName =
"# of Bytes sent / sec";
this.performanceCounterBytesSentPerSec.ReadOnly = false;
//
// performanceCounterRequestsTotal
//
this.performanceCounterRequestsTotal.CategoryName =
"Quote Service Counts";
this.performanceCounterRequestsTotal.CounterName =
"# of Requests";
this.performanceCounterRequestsTotal.Readonly = false;
// ...
Счетчики производительности, которые показывают общие значения, увеличиваются в методе Listener()
класса QuoteServer
. Метод Increment()
увеличивает счетчик на 1, метод IncrementBy()
увеличивает счетчик на значение аргумента.
Для счетчиков производительности, которые показывают посекундные значения, в методе Listener()
обновляются только две переменные — requestPerSec
и bytessPerSec
:
void protected void Listener() {
try {
listener = new TCPListener(port);
listener.Start();
while (true) {
Socket socket = listener.Accept();
if (socket == null) {
return;
}
string message = GetRandomQuoteOfTheDay();
UnicodeEncoding encoder = new UnicodeEncoding();
byte [] buffer = encoder.GetBytes(message);
socket.Send(buffer, buffer.Length, 0);
socket.Close();
performanceCounterRequestsTotal.Increment();
performanceCounterBytesSentTotal.IncrementBy(nBytes);
requestsPerSec++;
bytesPerSec += Bytes;
}
} catch (Exception e) {
string message = "Quote Server failed in Listener: " + e.Message;
eventLog.WriteEntry(message, EventLogEntryType.Error);
}
}
Чтобы показывать обновленные значения каждую секунду, используется компонент Timer
. Метод OnTimer()
вызывается раз в секунду и задает счетчики производительности с помощью свойства RawValue
класса PerformanceCounter
:
protected void OnTimer(object sender, system.EventArgs e) {
performanceCounterBytesSentPerSec.RawValue = bytesPerSec;
performanceCounterRequestsPerSec.RawValue = reguestsPerSec;
bytesPerSec = 0;
requestsPerSec = 0;
}
perfmon.exe
Теперь можно контролировать нашу службу. Утилита Performance может запускаться из Administrative Tools|Performance. Нажимая кнопку + в панели инструментов, можно добавить счетчики производительности. Quote Service будет определяться как объект производительности. Все сконфигурированные счетчики показаны в списке счетчиков:

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

Служба счетчика производительности
Если не существует ссылки на объект счетчика производительности, и объект был удален сборщиком мусора, счетчик этого объекта теряется и запускается в следующий раз с 0. Чтобы решить эту проблему, состояние можно хранить в службе счетчиков производительности. С помощью .NET Framework служба счетчиков производительности устанавливается в системе. Необходимо только запустить службу; можно также сконфигурировать службу для автоматического запуска во время начальной загрузки системы.
Читать дальшеИнтервал:
Закладка: