существует более одной службы и для них требуется некоторая общая инициализация, то эта общая инициализация должна делаться до метода
Run
, так как основной поток выполнения блокируется, пока служебный процесс не будет остановлен. Последующие инструкции остаются недоступными до конца службы.
Инициализация не может продолжаться слишком долго, время выполнения не должно превышать 30 с. Если код инициализации будет более длительным, то служебный управляющий менеджер предположит, что запуск службы отказал. Но необходимо принимать в расчет самые медленные машины, где эта служба также должна выполняться с учетом ограничения в 30 с. Если процесс продолжается дольше, можно запустить инициализацию в другом потоке выполнения, чтобы основной поток выполнения вызывал
Run
вовремя. Объект события может затем использоваться для сигнализации того, что поток выполнения закончил свою работу.
Запуск службы
При запуске службы вызывается метод
OnStart
. Здесь может начать работу сервер сокета. Чтобы использовать
QuoteServer
, должна быть указана сборка
Quote.Server.dll
. Поток выполнения, вызывающий
OnStart
, не может быть блокирован, этот метод возвращает управление вызывающей стороне, которая является методом
ServiceMainCallback
класса
ServiceBase
. Класс
ServiceBase
регистрирует обработчик и информирует SCM после вызова
OnStart
, что служба успешно запущена:
/// <summary>
/// Задает вещи по ходу, чтобы служба могла делать свою работу.
/// </summary>
protected override void OnStart(string[] args) {
quoteServer = new QuoteServer(@"c:\Wrox\quotes.txt", 5678);
quoteServer.Start;
}
Переменная
quoteServer
объявляется как закрытый член класса:
namespace Wrox.ProfessionalCSharp {
public class QuoteService : System.ServiceProcess.ServiceBase {
. Необходимо остановить функциональность службы в этом методе:
/// <summary>
/// Остановить эту службу. /// </summary>
protected override void OnStop {
quoteServer.Stop;
}
В дополнение к
OnStart
и
OnStop
можно переопределить в классе следующие обработчики:
□
OnPause
вызывается, когда служба должна быть временно остановлена.
□
OnContinue
вызывается, когда служба возвращается к нормальной работе после
временной остановки. Чтобы сделать возможным вызов перезагруженных методов
OnPause
и
OnContinue
, свойство
CanPauseAndContinue
должно быть задано как true.
□
OnShutdown
вызывается, когда Windows осуществляет выключение системы. Обычно поведение этого метода аналогично реализации
OnStop
: если для выключения потребуется больше времени, то запрашивается дополнительное время. Аналогично
OnPause
и
OnContinue
имеется свойство, чтобы включить такое поведение,—
CanShutdown
, которое должно быть задано как true.
□
OnCustomCommand
является обработчиком, который обслуживает специальные команды. С помощью специальной служебной управляющей программы службе посылаются особые команды. Как эти команды обрабатываются, определяет реализация
OnCustomCommand
. Этот метод имеет аргумент типа
int
, где задается номер специальной команды. Значение может быть в диапазоне от 128 до 256, значения меньше 128 являются зарезервированными системой значениями. В нашей службе повторное чтение файла цитат выполняется с помощью специальной команды 128:
При использовании служб мы имеем дело с потоками выполнения. Как мы говорили ранее, SCM предполагает, что служба отказала, если инициализация продолжается слишком долго. Чтобы справиться с этим, необходимо создать поток выполнения. Метод
OnStart
в служебном классе должен вернуть управление вовремя. Для вызова заблокированного метода, такого как
AcceptSocket
из класса
TopListener
, необходимо запустить поток выполнения. Если мы не находимся внутри
AcceptSocket
, то следующий клиент, запрашивающий службу, должен ожидать, пока мы там не окажемся. Это означает, что если для клиента нужно сделать некоторую работу, то используется пул потоков выполнения.
Установка службы
Служба должна конфигурироваться в реестре. Все службы можно найти в