IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Entrée/Sortie Java Discussion :

[Fichiers] écriture dans fichier


Sujet :

Entrée/Sortie Java

  1. #1
    kij
    kij est déconnecté
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    362
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 362
    Points : 157
    Points
    157
    Par défaut [Fichiers] écriture dans fichier
    Bonjour à tous,

    J'ai actuellement un soucis en java pour l'écriture de logs dans un fichier.
    J'ai un scénario (une classe java) chargée de faire un traitement et d'écrire les logs dans un fichier de rapport.
    Au début du thread j'initialise donc les différents fichiers de rapport en écrivant un "header" dans chaque fichier comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
            if (theReportType.equals(ERR_REPORT_TYPE) ) {
     
    		setErrorReportFileId(new RandomAccessFile(theReportFileName,"rw"));
    		getErrorReportFileId().seek(getErrorReportFileId().length());
    		header.append(ERROR_TITLE);
    		getErrorReportFileId().writeBytes(header.toString());
    	}
    Ce qui habituellement créé le fichier de rapport et le rempli par la chaine de caractère 'header'.
    Ce procédé fonctionne à merveille sauf sur l'une de mes classes :
    Les logs sont bel et bien écrits (trace à l'appuye) et mon fichier semble être créé au niveau du code (Si je fais un : getErrorReportFileId().lenght() la taille du fichier augmente à mesure que j'écrit dedans).

    Or si je vais voir dans le répertoire adéquat sous UNIX, le fichier correspondant n'est pas créé !!!
    Sous windows le fichier est créé !!

    Je ne comprends pourquoi le fichier n'est pas créé sous UNIX qui est un environement bien plus permissif que Window au niveau de la création de fichier...

    Est-ce que quelqun saurait d'où ce comportement peut venir ?

    Merci de votre aide.

  2. #2
    Rédacteur
    Avatar de CyberChouan
    Homme Profil pro
    Directeur technique
    Inscrit en
    Janvier 2007
    Messages
    2 752
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 752
    Points : 4 314
    Points
    4 314
    Par défaut
    Le "user" qui utilise ton application a-t'il bien les droits en écriture sur le répertoire visé sous UNIX (chmod/chown du répertoire)?

    As-tu bien pensé à faire un "flush()" après chaque écriture dans ta log? Le fichier n'est peut-être réellement créé sous UNIX qu'à ce moment là. De plus, cela assure que le fichier est créé et rempli, même si ton application s'arrête anormalement (coupure de courant...), ce qui est généralement le but recherché pour un fichier de log.

  3. #3
    kij
    kij est déconnecté
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    362
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 362
    Points : 157
    Points
    157
    Par défaut
    Mon user est un user spécial ayant tous les droits nécessaires pour exécuter, lire et écrire dans le répertoire ciblé.

    Je vais voir ce que ca donne en flushant.

  4. #4
    kij
    kij est déconnecté
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    362
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 362
    Points : 157
    Points
    157
    Par défaut
    Après quelques passage sur le code (à la base ce n'est pas le mien, dur dur de passer derrière quelqun ), j'ai constaté qu'il y a effectivement un problème de flush sur l'objet Log4j utilisé (ce qui fait planter l'écriture des rapports).

    Merci pour l'aide

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 5
    Dernier message: 15/10/2009, 20h59
  2. [VS2005]lecture/écriture dans fichier binaire
    Par shadowmoon dans le forum Windows Forms
    Réponses: 10
    Dernier message: 25/09/2007, 18h30
  3. Huffman et écriture dans fichier
    Par kuja2053 dans le forum C
    Réponses: 6
    Dernier message: 04/05/2007, 15h52
  4. Besoin d'aide écriture dans fichier
    Par boniface dans le forum Modules
    Réponses: 3
    Dernier message: 29/01/2007, 19h06
  5. Réponses: 2
    Dernier message: 15/11/2005, 10h58

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo