Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 01-03-2023
jars jars is offline
Miembro
 
Registrado: mar 2004
Posts: 279
Poder: 21
jars Va por buen camino
Generar logfile con varios archivos

Hola amigos.
Estoy usando en mis proyectos archivos de log que al llegar a un tamaño parametrizado se renombran y arranca uno nuevo. Es decir genero MiProyecto1.log y al llenarse, lo renombro como MiProyecto2.log y creo uno nuevo MiProyecto1.log.
Lo que estoy necesitando para un proyecto que genera muchísima información y llega al tamaño máximo muy rápido, es poder tener mas historia para poder auditar en caso de necesidad. Quisiera poder generar lo siguiente:
MiProyecto1.log, MiProyecto2.log, MiProyecto3.log, MiProyecto4.log, MiProyecto5.log, MiProyecto6.log, MiProyecto7.log, MiProyecto8.log, MiProyecto9.log, MiProyecto10.log
El problema es que a medida que se van llenando se van renombrando para que siempre el 1 es el actual, el que le sigue sea el 2 y el mas viejo el 10. Hay algo hecho así?
Gracias.
Responder Con Cita
  #2  
Antiguo 01-03-2023
lucho6007 lucho6007 is offline
Miembro
 
Registrado: ene 2009
Ubicación: Junín, pcia de BsAs, Argentina
Posts: 74
Poder: 16
lucho6007 Va por buen camino
Hola!
Lo razonable es que vayas llenando siempre el último archivo, y al llegar a X tamaño, generes un nuevo archivo con el nuevo nombre.
Podés tener una función que haga el log, y en esa función verificas el nombre del archivo y el tamaño.


Suerte!
Responder Con Cita
  #3  
Antiguo 01-03-2023
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.734
Poder: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Esta es una opción.
Lo que no se es cuanto tardará cuando haya cientos de ficheros log.
Esta función te renombra los ficheros posteriores al 1.
Luego tendrías que renombrar el 1 como 2 y reiniciar el log con el nuevo fichero 1.

Código Delphi [-]
procedure RotarLogs(NombreFichero : string);
var
  i : integer;
begin
  // Empiezo en el segundo, porque el primero es en el que se está escribiendo
  i := 2;
  
  // Busco el ultimo fichero de log
  while FileExists(NombreFichero+IntToStr(i)+'.log') do
     inc(i);
  
  // Recorro los ficheros log encontrados en forma inversa, renombrandolos con el numero siguiente  
  while (i > 2) do
  begin  
    dec(i);
    // *RenameFile* no se si existe en Delphi
    RenameFile(NombreFichero+IntToStr(i)+'.log', NombreFichero+IntToStr(i+1)+'.log');
  end;
end;
Responder Con Cita
  #4  
Antiguo 01-03-2023
Avatar de mamcx
mamcx mamcx is offline
Moderador
 
Registrado: sep 2004
Ubicación: Medellín - Colombia
Posts: 3.911
Poder: 25
mamcx Tiene un aura espectacularmamcx Tiene un aura espectacularmamcx Tiene un aura espectacular
Cita:
Empezado por jars Ver Mensaje
El problema es que a medida que se van llenando se van renombrando para que siempre el 1 es el actual, el que le sigue sea el 2 y
Asi tienes un problema de contención (puedes estar escribiendo el archivo mientras lo cambias de nombre) y es errado el algoritmo.

Lo que se hace es que tienes un archivo `x.log`. Cuando se llena, se copia a `x.1.log`, te vas de nuevo al inicio del archivo y sigues escribiendo.

De esta forma, solo `x.log` es accesado para escritura y el SO puede hacer cambios atómicos en los archivos al copiar.
__________________
El malabarista.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Generar Archivos PDF EdwinFC Varios 2 10-09-2008 09:11:16
generar archivos rar o zip johurgi Varios 14 09-06-2008 17:44:31
Logfile que es!!!! Yun-i Internet 6 26-03-2008 18:08:53
Generar archivos PDF en tus aplicaciones dec Trucos 3 16-04-2007 17:55:39
Generar varios Reports Igna Impresión 1 15-07-2004 12:23:19


La franja horaria es GMT +2. Ahora son las 21:27:46.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi