pcntl_signal

(PHP 4 >= 4.1.0)

pcntl_signal -- Installe un gestionnaire de signaux

Description

bool pcntl_signal ( int signo, callback handle [, bool restart_syscalls])

pcntl_signal() installe un nouveau gestionnaire de signaux opur le signal indiqué par le paramètre signo. Le gestionnaire de signaux est affecté à handler qui peut être le nom d'une fonction utilisateur, ou bien l'une des deux constantes globales SIG_IGN et SIG_DFL. Le paramètre optionnel restart_syscalls spécifie si l'appel système de redémarrage (restarting) doit être utilisé lorsque ce signal arrive, et par défaut, ce paramètre vaut TRUE.

Cette fonction retourne TRUE en cas de succès, FALSE en cas d'échec.

Note : La possibilité d'utiliser une méthode d'objet comme fonction de callback est disponible depuis PHP 4.3.0. Notez que lorsque vous configurez le gestionnaire avec une méthode d'objet, le compteur de référence de l'objet est incrémenté, ce qui le rend persistant jusqu'à ce que vous changiez le gestionaire de signeux pour un autre, ou que le script se termine.

Exemple 1. Exemple avec pcntl_signal()

<?php
// l'usage des tick est n&eacute;cessaire depuis PHP 4.3.0
declare (ticks = 1);

// gestionnaire de siganux syst&egrave;me
function sig_handler($signo) {

     switch(
$signo) {
         case
SIGTERM:
             
// gestion de l'extinction
             
exit;
             break;
         case
SIGHUP:
             
// gestion du red&eacute;marrage
             
break;
         case
SIGUSR1:
             print
"Re&ccedil;u le signe SIGUSR1...\n";
             break;
         default:
             
// gestion des autres signaux
     
}

}

print
"Installation du gestionnaire de signaux...\n";

// Installation des gestionnaires de signaux
pcntl_signal(SIGTERM, "sig_handler");
pcntl_signal(SIGHUP,  "sig_handler");
pcntl_signal(SIGUSR1, "sig_handler");

// ou bien utilisez un objet (disponible depuis PHP 4.3.0)
// pcntl_signal(SIGUSR1, array($obj, "faire_quelquechose");

print "G&eacute;n&eacute;ration d'un signal SIGTERM &agrave; moi m&ecirc;me...\n";

// envoi de SIGUSR1 &agrave; l'identifiant de processus courant
posix_kill(posix_getpid(), SIGUSR1);

print
"Done\n"

?>

Voir aussi pcntl_fork() et pcntl_waitpid().