(PECL win32service SVN)
win32_start_service_ctrl_dispatcher — Enregistre un script avec SCM, alors il peut être interprété en tant que service avec le nom donné
Lorsque exécuté via le Gestionnaire de Contrôle de Service, un processus de service est requis pour "archiver" avec lui pour établir un service de surveillance et de communication ergonomique. Cette fonction effectue un archivage en démarrant un thread pour gérer les communications de bas niveau avec le gestionnaire de contrôle de service.
Une fois démarré, le processus du service doit faire 2 choses. La première
est d'indiquer au Service Control Manager que le service est en cours
d'exécution. La seconde est d'appeler la fonction
win32_set_service_status() avec la constante
WIN32_SERVICE_RUNNING
. Si vous avez besoin de
lancer des processus longs avant que le service ne soit lancé, alors
vous pouvez utiliser la constante WIN32_SERVICE_START_PENDING
.
La seconde est de continuer à vérifier en utilisant le Service Control Manager
sachant qu'il peut déterminer si le service se termine ou non. Ceci consiste
à appeler, périodiquement, la fonction win32_get_last_control_message()
et à traiter le code retourné.
Depuis la version 0.2.0, cette fonction fonctionne uniquement en ligne de commande. Elle est désactivé dans les autres cas.
Returns TRUE
on success, FALSE
if there is a problem with the parameters or a Win32 Error Code on failure.
Exemple #1 Exemple avec win32_start_service_ctrl_dispatcher()
Vérifie si le service fonctionne sous SCM.
<?php
if (!win32_start_service_ctrl_dispatcher('dummyphp')) {
die("Je ne fonctionne probablement pas sous le gestionnaire de contrôle de service");
}
win32_set_service_status(WIN32_SERVICE_START_PENDING);
// Quelques processus longs à récupérer pendant que le service fonctionne.
win32_set_service_status(WIN32_SERVICE_RUNNING);
while (WIN32_SERVICE_CONTROL_STOP != win32_get_last_control_message()) {
# effectuer votre travail ici.
# essayez de ne pas prendre plus de 30 secondes avant de retourner au
}
?>
Version | Description |
---|---|
0.2.0 | Cette fonction fonctionne uniquement en ligne de commande. |