#!/usr/bin/php4 -qC ------------------------------------------------------------------------------- $Id$ -----------------------------------------------------------------------------*/ //XXX LANZAR ESTE SCRIPT CON NICE -19 //YATTA LOG {{{ function yatta_log ($texto) { GLOBAL $YATTA_SERVER; GLOBAL $FH; $linea = strftime("%b %e %H:%M:%S").' '.$YATTA_SERVER['name'].' '. $YATTA_SERVER['script'].'['.$YATTA_SERVER['pid'].']: '. $texto ."\n"; fwrite($FH, $linea); } //}}} //Leo el archivo de configuracion {{{ $CONF = parse_ini_file(dirname(__FILE__) . '/configuracion.ini', true); //}}} //ABRO EL ARCHIVO DE LOG {{{ //Como root: //# touch /var/log/apache/YATTA_Server.log //# chown root.www-data /var/log/apache/YATTA_Server.log //# chmod 660 /var/log/apache/YATTA_Server.log if (!($FH = fopen ($CONF['server']['log'], "a"))) { trigger_error("No se pudo abrir el archivo de log. Se detiene el script.", E_USER_ERROR); } //}}} //REQUIRE ONCE {{{ require_once 'PEAR.php'; require_once 'YATTA/Controlador.php'; require_once 'YATTA/Servidor.php'; require_once 'YATTA/DB.php'; //}}} //CREO UNA CONEXION MYSQL{{{ $db = YATTA_DB::connect($CONF['db']); if (DB::isError($db)) { trigger_error($db->getMessage(), E_USER_ERROR); } //}}} //CREO LOS OBJETOS NECESARIOS {{{ $CONTROLADOR =& new YATTA_Controlador; $SERVIDOR =& new YATTA_Servidor; //}}} //OBTENGO LOS DATOS DEL SERVER {{{ $YATTA_SERVER['script'] = $argv[0]; $YATTA_SERVER['pid'] = getmypid(); $YATTA_SERVER['name'] = substr(file_get_contents('/etc/hostname'), 0, strpos (file_get_contents('/etc/hostname'), "\n")); $YATTA_SERVER['id'] = $SERVIDOR->obtenerId($db, $YATTA_SERVER['name']); if (PEAR::isError($YATTA_SERVER['id'])) { trigger_error('Error: ' . $YATTA_SERVER['id']->getMessage() . "\n", E_USER_ERROR); } yatta_log ('*************** Comienzo Ejecución ***************'); yatta_log (' SCRIPT: ' . $YATTA_SERVER['script']); yatta_log (' PID: ' . $YATTA_SERVER['pid']); yatta_log (' SERVER NAME: ' . $YATTA_SERVER['name']); yatta_log (' SERVER ID: ' . $YATTA_SERVER['id']); yatta_log ('**************************************************'); //}}} //WHILEO LAS OPCIONES {{{ while (1) { //Busco un nuevo proceso {{{ $proceso = $CONTROLADOR->obtenerNuevoProceso($db, $YATTA_SERVER['id']); yatta_log ('Se busca un nuevo proceso.'); //}}} //Si hay un proceso lo lanzo {{{ if (@$proceso) { yatta_log ('Hay un nuevo proceso. Se forkea'); $pid = pcntl_fork(); //FORK ERROR {{{ if ($pid == -1) { yatta_log('ERROR: No se pudo forkear.'); $res = $CONTROLADOR->terminarProceso($db, $proceso['id'], $YATTA_SERVER['id'], 3, 'No se pudo forkear el script.'); if (PEAR::isError($res)) { yatta_log('ERROR: YATTA_Controlador. '.$res->getMessage()); } } //}}} //FORK PADRE {{{ elseif ($pid) { yatta_log ('Fork Padre.'); //Espero a que termine el proceso. yatta_log ('Se espera a que termine el proceso en ejecución. Se'. ' verificara si hay que abortar el proceso cada 5 segundo.'); while (($wapid = pcntl_waitpid ($pid, $status, WNOHANG)) != $pid) { if ($CONTROLADOR->abortar($db, $proceso['id'])) { yatta_log ('Hay que abortar el proceso en ejecución.'); posix_kill($pid, 15); //SIGTERM $CONTROLADOR->terminarProceso($db, $proceso['id'], $YATTA_SERVER['id'], 4); yatta_log ('Se aborto el proceso en ejecución.'); } sleep(10); } yatta_log ('Fin fork Padre.'); } //}}} //FORK HIJO {{{ else { yatta_log ('Fork Hijo.'); require_once $proceso['script']; yatta_log ('Se crea el proceso..'); if (function_exists('create_process')) { $SCRIPT =& create_process(); yatta_log ('Se instancio el proceso. Se ejecuta el metodo run.'); if (!method_exists($SCRIPT, 'run')) { yatta_log ('No existe el metodo run en el proceso.'); require_once 'YATTA/Proceso.php'; $SCRIPT =& new YATTA_Proceso; $SCRIPT->error = 'No existe el metodo run en'. $proceso['script']; } else { yatta_log ('Comienza la ejecución del proceso.'); $SCRIPT->run(unserialize($proceso['parametros'])); yatta_log ('Finaliza la ejecución del proceso.'); } } else { require_once 'YATTA/Proceso.php'; $SCRIPT =& new YATTA_Proceso; $SCRIPT->error = 'No existe la funcion create_process en'. $proceso['script']; } if (@$SCRIPT->error) { $estado = 3; } else { $estado = 2; } $CONROLADOR->terminarProceso($db, $proceso['id'], $YATTA_SERVER['id'], $estado, @$SCRIPT->error, @$SCRIPT->archivo, @$SCRIPT->notificar); yatta_log ('Fin fork Hijo.'); } //}}} } // }}} //No hay proceso {{{ else { yatta_log ('No hay procesos asignados a este servidor.'. ' En 60 segundos se buscara un nuevo proceso.'); sleep(60); } //}}} } //}}} //CIERRO EL ARCHIVO DE LOG {{{ yatta_log ('*************** Finaliza Ejecución ***************'); fclose ($FH); //}}} ?>