Вопрос 9. Службы в ОС Windows : назначение, основные принципы функционирования, отличие от драйверов. Порядок установки службы в ОС Windows .
Добавил: | DMT |
Дата создания: | 30 декабря 2007, 18:59 |
Дата обновления: | 10 января 2008, 0:06 |
Просмотров: | 14456 последний сегодня, 21:08 |
Комментариев: | 0 |
Вопрос 9. Службы в ОС Windows : назначение, основные принципы функционирования, отличие от драйверов. Порядок установки службы в ОС Windows . Службы - это программы, работающие вне контекста пользователя. Службы продолжают работать даже тогда, когда один пользователь отключается от системы и к ней подключается другой пользователь. Это единственная категория программ, которые способны работать в таком режиме. С точки зрения программиста, службы - это программы (чаще всего консольные), обладающие средствами связи с диспетчером служб SCM ( Service Control Manager ). Диспетчер SCM — это внутренний механизм Windows , осуществляющий управление службами. В Windows NT 4 пользователь взаимодействует с SCM при помощи апплета Services Control Panel . В Windows 2000 ту же функцию выполняет один из модулей консоли ММС. Архитектура системных служб Windows NT подразумевает три вида. Ee ядром является менеджер системных служб ( Service Control Manager или SCM). SCM запускается при загрузке системы и работает, пока компьютер не будет выключен. Менеджер системных служб взаимодействует с одной стороны с управляющими программами , а с другой - с системными службами . Основными задачами менеджера являются:
Windows NT определяет два вида системных служб. Один из них - это так называемые службы режима ядра ( kernel-mode services ) - драйверы устройств. Другой вид - службы Win32 , обычные Win32-процессы, использующие специальный набор функций для взаимодействия с менеджером системных служб. Служба обладает функцией main . Одна программа может обеспечивать работу одной службы, а может включать в себя сразу несколько служб. Функция main заполняет массив, описывающий все поддерживаемые программой службы. Массив передается вызову StartServiceCtrlDispatcher . Для каждой службы, входящей в состав исполняемого файла, этот массив содержит текстовый идентификатор и точку входа. Точка входа службы - функция типа void , принимающая обычные аргументы argc и argv . Но в отличие от аргументов функции main , аргументы точки входа службы не связаны с командной строкой. Они заполняются диспетчером SCM . В процессе обращения SCM к функции, которая является точкой входа службы, важную роль играет структура SERVICE _ STATUS . Функция, являющаяся точкой входа, использует вызов RegisterServiceCtrlHandler для того, чтобы зарегистрировать обработчик, предназначенный для взаимодействия SCM со службой. Помимо этого подпрограмма инициализации службы обращается к вызову SetServiceStatus для того, чтобы проинформировать SCM о текущем состоянии службы (служба может находиться в одном из состояний: инициализация, функционирование или остановка). Если инициализация требует более чем несколько секунд, рекомендуется выполнить ее в отдельном программном потоке. Создание отдельного программного потока потребуется также в случае, если вы намерены создать службу, которая будет работать исключительно в фоновом режиме. Когда диспетчер SCM желает тем или иным образом обратиться к службе, он обращается к обработчику, зарегистрированному при помощи вызова RegisterServiceCtrlHandler . Чаще всего это происходит тогда, когда диспетчер SCM желает завершить работу службы, приостановить ее исполнение или продолжить ее работу после паузы. Диспетчер SCM обращается к обработчику также в случае, если требуется определить текущее состояние службы. Помимо этого служба может определять другие специальные виды запросов, которые можно адресовать службе при помощи вызова Control Service (этот вызов является частью диспетчера SCM ). Для того чтобы направить службе запрос, необходимо обладать необходимыми полномочиями.
Установка служб Чтобы установить службу, необходимо добавить в реестр несколько записей. Чаще всего эта процедура выполняется при помощи SCM . Для этого необходимо открыть SCM (при помощи вызова OpenSCManager ), а затем обратиться к вызову CreateService . В качестве аргументов этот вызов принимает имя файла, в котором содержится служба, а также другую необходимую информацию. Затем функция StartService , посылает запрос на запуск службы менеджеру системных служб. SCM определяет, что процесс, соответствующий службе, еще не запущен, поэтому он вызывает функцию CreateProcessAsUser , передавая ей командную строку, указанную в конфигурации службы. Далее стартует процесс службы. Управление передается функции WinMain (или просто main ) процесса службы. Произведя необходимую инициализацию, WinMain вызывает функцию StartServiceCtrlDispatcher , которая реализует цикл приема и обработки команд SCM. StartServiceCtrlDispatcher устанавливает соединение со SCM и сразу же получает от него первую команду, а именно команду на запуск службы. Кроме того, менеджер системных служб сообщает приложению, запустившему службу, что служба начала выполняться. Именно в этот момент StartService возвращает управление прикладной программе. Получив команду на запуск службы, StartServiceCtrlDispatcher создает новый поток вызовом CreateThread , в котором вызывает главную функцию службы, обычно имеющую название ServiceMain . Непосредственно перед созданием потока StartServiceCtrlDispatcher вызывает SetServiceStatus чтобы установить текущее состояние службы в SERVICE_START_PENDING, указывая при этом dwCheckPoint как 0 и dwWaitHint как 2000. Функция службы получает управление и одним из первых действий вызывает функцию RegisterServiceCtrlHandler , чтобы зарегистрировать функцию-обработчик команд для этой службы. Служба выполняет инициализацию, например, после чего вызывает SetServiceStatus , указывая состояние SERVICE_RUNNING. С этого момента служба считается стартовавшей. Основное отличие драйвера от службы заключается в том, что драйвер может работать в 0 кольце и в пользовательском режиме, а служба работает только в пользовательском режиме. Установка службы осуществляется через SCM менеджер, а драйвер через . inf файл, однако драйвер может быть установлен через SCM менеджер, но не все типы драйверов могут установлены через SCM менеджер.
Код службы, которая издает звуковой сигнал в начале каждого часа (период времени можно изменить из командной строки):
|