(PECL win32service >=0.1.0)
win32_start_service_ctrl_dispatcher — Добавляет в Диспетчер Служб скрипт, который может быть использован, как служба с заданным именем
При запуске с помощью диспетчера служб, процессу службы необходимо сверяться с ним для мониторинга службы и связи с ней. Эта функция выполняет сверку посредством создания потока для обработки низкоуровневой связи с диспетчером служб.
После запуска процесс службы должен осуществить два действия. Первое - сообщить
диспетчеру служб, что служба запущена. Это осуществляется путем вызова win32_set_service_status()
с константой WIN32_SERVICE_RUNNING
. Если вам необходимо выполнить
некий длительный процесс перед запуском службы, то вы можете использовать константу
WIN32_SERVICE_START_PENDING
. Второе - продолжить сверку с диспетчером
служб, чтобы определить необходимость отключения. Это осуществляется посредством
периодического вызова win32_get_last_control_message() и обработки
кода возврата соответствующим образом.
Начиная с версии 0.2.0, эта функция работает только в "cli" SAPI. В прочих SAPI функция отключена.
name
Короткое имя службы, как при добавлении с помощью win32_create_service().
gracefulMode
TRUE
для "элегантного" выхода. FALSE
для выхода с ошибкой. Смотрите
win32_set_service_exit_mode() для получения подробной информации.
Возвращает TRUE
в случае успешного завершения, FALSE
если была обнаружена проблема с параметрами или код ошибки Win32 при неудачном завершении работы.
Если SAPI не является "cli", данная функция вызывает ошибку уровня E_ERROR
.
Пример #1 Пример win32_start_service_ctrl_dispatcher()
Проверьте, запущен ли сервис в диспетчере служб.
<?php
if (!win32_start_service_ctrl_dispatcher('dummyphp')) {
die("Я, вероятно, не запущен в диспетчере служб");
}
win32_set_service_status(WIN32_SERVICE_START_PENDING);
// Некий длительный процесс для обработки и запуска службы.
win32_set_service_status(WIN32_SERVICE_RUNNING);
while (WIN32_SERVICE_CONTROL_STOP != win32_get_last_control_message()) {
# здесь производятся какие-то действия, не занимающие больше чем 30 секунд
# перед соответствующим переходом в цикл.
}
?>
Версия | Описание |
---|---|
0.4.0 |
Добавлен параметр gracefulMode .
|
0.2.0 | Эта функция работает только с "cli" SAPI. |