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

ЖАНРЫ

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

Ватсон Карли

Шрифт:

InstallUtil

После добавления в проект классов для установки можно воспользоваться утилитой

installutil.exe
для установки и удаления cлужбы. Ввод командной строки для этих действий выглядит соответственно:

installutil quoteservice.exe

installutil /u quoteservice.exe

Если установка отказывает, проверьте файлы регистрации установки

InstallUtil.InstallLog
и
<имя_службы>.InstallLog
. Там можно найти очень полезную информацию, такую как "Указанная служба уже существует".

Клиент 

После успешной установки службы и запуска ее вручную (см. следующий раздел для дальнейших указаний) можно запустить клиент, используя службы ММС со следующими настройками.

Мониторинг

и управление службой

Для мониторинга и управления службой имеется несколько утилит. Они относятся к службам консоли ММС, которая, в свою очередь, является частью административной утилиты управления компьютером. Для каждой оконной системы мы получаем также утилиту командной строки

net.exe
, позволяющую управлять службами,
sc.exe
служит дополнительной утилитой командной строки, которая имеет значительно больше функций, чем команда
net.exe
, являющаяся частью Platform SDK. Мы создадим небольшое приложение Windows, использующее класс
System.ServiceProcess.ServiceController
для мониторинга и управления службами.

Консоль управления Microsoft (ММС)

Используя подключаемый модуль (snap-in) Services из консоли управления Microsoft (ММС), можно увидеть статус всех служб. Также можно послать службам управляющие запросы для останова, включения, выключения и изменения конфигурации. Подключаемый модуль Services является служебной управляющей, а также служебной конфигурационной программой:

Двойной щелчок на

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

net.exe

Подключаемый модуль

Services
использовать легко, но системный администратор не может его автоматизировать, так как его нельзя применить внутри административного сценария. Системный администратор может написать программу для Windows Scripting Host, чтобы облегчить свою повседневную работу. Для этой задачи существует утилита командной строки
net.exe
, имеющаяся в любой установленной системе Windows. Эта утилита используется для управления службами,
net start
показывает все выполняющиеся службы,
net start имя_службы
запускает службу,
net stop имя_службы
посылает службе запрос останова. Можно также временно остановить и продолжить работу службы с помощью
net pause
и
net continue
(конечно, если служба это допускает).

Результаты

net start
показаны в консольном окне:

sc.exe

Существует малоизвестная утилита

sc.exe
, которая является частью Microsoft Platform SDK. Необходимо установить Microsoft Platform SDK, чтобы получить доступ к этой утилите. Microsoft Platform SDK не является частью компакт-диска Visual Studio.NET. Этот дополнительный компакт-диск — часть MSDN, его можно загрузить из Интернета для подписчиков MSDN. Обычный путь доступа для установки такой утилиты —
с:\Program Files\Microsoft Platform SDK\Bin\WinNT
.

sc.exe
— хорошая утилита для работы со службами. С ней можно сделать значительно больше по сравнению с утилитой
net.exe
. С помощью
sc
проверяется реальный статус, конфигурируются, удаляются и добавляются службы. Эта утилита помогает в том случае, когда удаление службы не может производиться обычным образом.

Server Explorer

Управлять службами можно также с помощью Server Explorer из Visual Studio.NET. Если вы не находите Server Explorer в текущей конфигурации, можно сделать его видимым с помощью меню View|Server Explorer. Выбирая службу и открывая контекстное меню, запускают и останавливают службу. Это контекстное меню также используется для добавления в проект класса

ServiceController
. Если вы желаете управлять специфической службой в приложении, перетащите службу из Server Explorer в конструктор — экземпляр
ServiceController
добавится в приложение. Свойства этого объекта автоматически задаются для доступа к выбранной службе и создается ссылка на
System.ServiceProcess.dll
. Можно использовать этот экземпляр для управления службой таким же образом, как мы это делаем в следующем разделе в базовом приложении для управления всеми службами.

Класс ServiceController

Создадим небольшое оконное приложение с помощью класса

ServiceController
для мониторинга и управления оконными службами.

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

для отправки управляющих сообщений.

Здесь используется класс

System.ServiceProcess.ServiceController
, поэтому необходимо иметь ссылку на
System.ServiceProcess.dll
.

Мы реализуем метод

RefreshServiceList
, который вызывается в конструкторе класса
ServiceControlForm
. Этот метод заполняет окно списка внешними именами всех служб.
GetServices
является статическим методом класса
ServiceController
, и он возвращает массив
ServiceController
, представляющий все службы Windows. Класс
ServiceController
также имеет статический метод
GetDevice
, который возвращает массив
ServiceController
, представляющий все драйверы устройств.

Окно списка заполняется с помощью связывания данных:

private System.ServiceProcess.ServiceController[] services;

public ServiceControlForm {

 //

 // Требуется для поддержки Windows Form Designer

 //

 InitializeComponent;

 RefreshServiceList;

}

protected void RefreshServiceList {

 services = ServiceController.GetServices;

 listBoxServices.DisplayMember = "DisplayName";

 listBoxServices.DataSource = services;

}

Теперь все службы Windows выводятся в окне списка и можно получить данные о каждой службе. Класс

ServiceController
имеет следующие свойства для данных о службе:

Свойства
ServiceController
CanPauseAndContinue
Если службе можно послать запрос pause и continue, то возвращается
true
.
CanShutdown
true
, если служба имеет программу обработки для выключения системы.
CanStop
true
, если службу можно остановить.
DependentServices
Возвращает совокупность подчиненных служб. Если служба остановлена, то все подчиненные службы заранее останавливаются.
ServicesDependentOn
Возвращаем совокупность служб, которые зависят от этой службы.
DisplayName
Имя, которое должно выводиться для этой службы.
MachineName
Имя машины, на которой выполняется эта служба.
ServiceName
Имя службы.
ServiceType
Служба может выполняться внутри общего процесса, где более одной службы используют один и тот же процесс (
Win32ShareProcess
), или выполняться так, что существует только одна служба внутри процесса (
Win32OwnProcess
). Если служба может взаимодействовать с рабочим столом компьютера, то тип будет
InteractiveProcess
.
Status
Статус службы. Статус может быть running, stopped paused или в некотором промежуточном режиме, таком как start pending, stop pending и т.д.

В рассматриваемом приложении используются свойства

DisplayName
,
ServiceName
,
ServiceType
и
Status
для вывода данных о службе, а также
CanPauseAndContinue
и
CanStop
для включения и отключения кнопок
Pause
,
Continue
и
Stop
.

Метод

OnSelectedIndexChanged
является методом обработки для окна списка. Он вызывается, когда пользователь
выбирает
службу в окне списка. В методе
OnSelectedIndexChanged
внешнее имя и имя свойства задаются непосредственно с помощью свойств класса ServiceController. Статус и тип не могут просто задаваться, так как должна выводиться строка вместо числа, которое возвращает класс
ServiceController
. Метод
SetServiceStatus
является вспомогательной функцией, просматривающей перечисление свойств
Status
для выводa строки статуса, а также включает и отключает кнопки.
GetServiceTypeName
создает имя типа службы.
ServiceType
мы получаем из
ServiceController.ServiceType
представляет множество флажков, которые могут комбинироваться с помощью побитового оператора
ИЛИ
. Бит
InteractiveProcess
может задаваться вместе с
Win32OwnProcess
и
Win32ShareProcess
. Необходимо проверить, задан ли бит
InteractiveProcess
прежде чем переходить к проверке других значений:

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