This is a Timer example use pcntl and libevent
function newChild($func_name) {
echo "enter newChild\n";
$args = func_get_args();
unset($args[0]);
$pid = pcntl_fork();
if ($pid == 0) {
function_exists($func_name) and exit(call_user_func_array($func_name, $args)) or exit(-1);
} else if($pid == -1) {
echo "Couldn't create child process";
} else {
return $pid;
}
}
function on_timer() {
echo "timer called\n";
}
/**
* @param $func string, function name
* @param $timeouts int, microtimes for time delay
*/
function timer($func, $timeouts){
echo "enter timer\n";
$base = event_base_new();
$event = event_new();
event_set($event, 0, EV_TIMEOUT, $func);
event_base_set($event, $base);
event_add($event, $timeouts);
event_base_loop($base);
}
$pid = newChild("timer", "on_timer", 5000000);
if ($pid > 0) {
echo "master process exit\n";
}
event_add
(PECL libevent >= 0.0.1)
event_add — Añade un evento al conjunto de eventos monitorizados
Descripción
event_add() planifica la ejecución de event
cuando el evento especificado en event_set() ocurra en como mínimo el tiempo
especificado por el parámetro timeout . Si no se ha especificado el parámetro
timeout , no se tendrá en cuenta ningún timeout. El evento
event debe ser inicializado antes por las funciones event_set()
y event_base_set() . Si el evento
event ya tenía un timeout configurado, se reemplazará por
el nuevo.
Parámetros
-
event -
Evento válido.
-
timeout -
Timeout opcional (en microsegundos).
Valores devueltos
event_add() devuelve TRUE en caso de éxito o FALSE en caso de error.
zhaoyong dot lc at gmail dot com ¶
2 months ago
