win32_start_service_ctrl_dispatcher
(PECL win32service >=0.1.0)
win32_start_service_ctrl_dispatcher — Добавляет в Диспетчер Служб скрипт, который может быть использован, как служба с заданным именем
Описание
win32_start_service_ctrl_dispatcher(
string $name
,
bool $gracefulMode
= true):
void
После запуска процесс службы должен осуществить два действия. Первое - сообщить
диспетчеру служб, что служба запущена. Это осуществляется путём вызова win32_set_service_status()
с константой WIN32_SERVICE_RUNNING
. Если вам необходимо выполнить
некий длительный процесс перед запуском службы, то вы можете использовать константу
WIN32_SERVICE_START_PENDING
. Второе - продолжить сверку с диспетчером
служб, чтобы определить необходимость отключения. Это осуществляется посредством
периодического вызова win32_get_last_control_message() и обработки
кода возврата соответствующим образом.
Предостережение
Начиная с версии 0.2.0, эта функция работает только в "cli" SAPI. В прочих SAPI
функция отключена.
Возвращаемые значения
Функция не возвращает значения после выполнения.
До версии 1.0.0, Возвращает WIN32_NO_ERROR
в случае успешного завершения , false
если была обнаружена проблема с параметрами или код ошибки Win32 при неудачном завершении работы.
Ошибки
До версии 1.0.0, если SAPI не является "cli"
, данная функция вызывает ошибку уровня E_ERROR
.
Начиная с версии 1.0.0, выбрасывает исключение
Win32ServiceException, если SAPI не является "cli"
Примеры
Пример #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 секунд
# перед соответствующим переходом в цикл.
}
?>