Foros del Web » Programando para Internet » PHP »

Mis scripts ocupan mucha ram, como optimizarlos?

Estas en el tema de Mis scripts ocupan mucha ram, como optimizarlos? en el foro de PHP en Foros del Web. Estimados Amigos, Tengo un script que corrige caracteres extraños en un archivo .sql de 18mb, pero al momento he ha colocado un limitacion de recursos ...
  #1 (permalink)  
Antiguo 06/02/2007, 10:07
 
Fecha de Ingreso: mayo-2002
Ubicación: Ecuador
Mensajes: 74
Antigüedad: 21 años, 11 meses
Puntos: 0
Mis scripts ocupan mucha ram, como optimizarlos?

Estimados Amigos,

Tengo un script que corrige caracteres extraños en un archivo .sql de 18mb, pero al momento he ha colocado un limitacion de recursos en mi server, dado que este consumia muchos recursos, por lo cual da el siguiente error:

Fatal error: Out of memory (allocated 57671680) (tried to allocate 19039279 bytes) in /home/myuser/public_html/script/change.php on line 20

He probado agregando al .htaccess la siguiente linea

php_value memory_limit 64M

pero me da un error 500 (Internal Server Error) debido a la misma limitacion del server... por lo cual me gustaria saber como puedo optimizar el script que copio acontinuacion:

Código PHP:
<?php
$nombre_archivo 
'/home/myuser/public_html/db/dbfile.sql';
$cambiar = array("D'O""\',""T'S""A 'J""AGUILERA'""F'""/','""O 'OR");
$cambiarpor = array("D´O"" ',""T\'S""A ´J""AGUILERA´""F\'"" ','""O ´OR");

// Aseguro que el archivo existe y puede escribirse sobre el.
if (is_writable($nombre_archivo)) {

   
// Abrimos el archivo.
   
if (!$gestor fopen($nombre_archivo'r+')) {
         echo 
"No se puede abrir el archivo ($nombre_archivo)";
         exit;
   }
    
   
// Leemos el archivo
   
$archivo fread($gestorfilesize($nombre_archivo));

   
// reemplazamos
   
$contenido str_replace($cambiar,$cambiarpor,$archivo);

   
fclose($gestor);

   
// Abrimos el archivo.
   
if (!$gestor2 fopen($nombre_archivo'w+')) {
         echo 
"No se puede abrir el archivo ($nombre_archivo)";
         exit;
   }

   
//escribirmos el archivo
   
if (fwrite($gestor2$contenido) === FALSE) {
       echo 
"No se puede escribir al archivo ($nombre_archivo)";
       exit;
   }
  
   echo 
"Con exito se cambio el archivo ($nombre_archivo)";
  
   
fclose($gestor2);

} else {
   echo 
"No se puede escribir sobre el archivo $nombre_archivo";
}
?>
Luego el mismo archivo lo subo a mysql con el siguiente script:

Código PHP:
<?php
$dbh
=mysql_connect ("localhost""db_user""dbpass");
mysql_select_db ("db_db",$dbh);

mysql_query("TRUNCATE TABLE `data`");

$ultima_linea system('mysql -u db_user -dbpass db_db < /home/myuser/public_html/db/dbfile.sql'$retval);

// ver resultados
echo "
<hr />Ultima linea de la salida: " 
$ultima_linea "
<hr />Valor de retorno: " 
$retval;
?>
Aunque no he tenido problemas al subir el archivo, me gustaria optimizar en lo posible recursos, que recomendaciones me pueden dar?

Cordiales Saludos,
  #2 (permalink)  
Antiguo 06/02/2007, 10:26
Avatar de emiliodeg  
Fecha de Ingreso: septiembre-2005
Ubicación: Córdoba
Mensajes: 1.830
Antigüedad: 18 años, 7 meses
Puntos: 55
Re: Mis scripts ocupan mucha ram, como optimizarlos?

no probaste con set_time_limit(0);???
  #3 (permalink)  
Antiguo 06/02/2007, 12:59
Avatar de DeeR  
Fecha de Ingreso: diciembre-2003
Ubicación: Santiago
Mensajes: 520
Antigüedad: 20 años, 4 meses
Puntos: 17
Re: Mis scripts ocupan mucha ram, como optimizarlos?

Haber a simple Vista de tu Script.
En una Sola Variable estas metiendo un Archivo de 18mb, es decir esa variable pesa 18mb.

Al parecer, lo que te puede ayudar a optimizar el Scripts, es lo siguiente
1.- Leer el Fichero por Linea
2.- Aplicar a la Linea una funcion que corrija los Caracteres
3.- Mandar la Linea a una Funcion que Cree un Archivo

La funcion nuevoarchivo debes crearla, y deberia ser una funcion que reciba por parametro una linea, y la agregue al final de un archivo (que este archivo siempre sea el mismo, se entiende la idea). Entonces si esa funcion la llamamos 100 veces, vamos a tener un archivo con 100 lineas.

De esta forma no usamos tantos recursos, ya que vamos trabajando Linea por Linea (Leyendo una Linea, Corrigiendo la Linea, Guardando la Linea).

Código PHP:
<?
//Abrimos el Archivo
$archivo fopen("bd.sql" "r");
if (
$archivo)
{
    while (!
feof($archivo))
    {
         
// En $linea tenemos la linae del Archivo
        
$linea fgets($archivo4096);
        
// Aplicai dos Funciones
        
$linea=corregir($linea);
        
nuevoarchivo($linea);
                
    }
}
fclose ($archivo);
?>

Lo otro si de ta muxa lata OPTIMIZAR tu Script, al parecer esta tarea que estas haciendo lo haces una vez nomas, lo que puedes hacer es trabajar en tu propia maquina, editai valos del php.ini (para la memoria y tiempo de ejecucion del script), dejai que el script trabaje en tu archivo, y finalmente (despues de un buen rato xD) vas a tener tu fichero.sql correjido, lo subes y lo cargai en tu mysql de tu server

Última edición por DeeR; 06/02/2007 a las 13:00 Razón: Olvido :P
  #4 (permalink)  
Antiguo 11/02/2007, 21:57
 
Fecha de Ingreso: mayo-2002
Ubicación: Ecuador
Mensajes: 74
Antigüedad: 21 años, 11 meses
Puntos: 0
Re: Mis scripts ocupan mucha ram, como optimizarlos?

Afirmativamente cargaba 18mb en una variable... al momento lo he solucionado corrigiendolo antes de subirlo... pero verificare las recomendaciones, sobre todo editarlo por lineas, para tratar de no cargar el server...

Salud!
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 21:34.