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

Java Discussion :

Accès disques ultra lents en java 1.5 sur Windows 8


Sujet :

Java

  1. #1
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut Accès disques ultra lents en java 1.5 sur Windows 8
    Bonjour,

    Je rencontre un problème avec une application Eclipse RCP (mais je ne pense pas que cela ait un lien) s'exécutant en java 1.5 (je ne peux pas migrer en 1.7, mais c'est une autre histoire), sous Windows 8.

    Dans cette application, on peut ouvrir des fichiers qui sont traités par des applications externes, non java (Adobe InDesign et Photoshop, pour ne pas les citer). Les fichiers sont téléchargés depuis un serveur (CMS) dans un dossier de travail local (situé dans le workspace de l'application), chaque fichier (accompagné d'autres fichiers) dans un dossier spécifique, puis l'application locale est lancée (comme c'est du java 1.5, avec un Runtime.exec.

    Lorsque l'utilisateur sauvegarde dans l'application externe, un process de mon application prend la main sur la sauvegarde pour renvoyer le fichier au serveur. Ceci fait un traitement relativement complexe, puisque le document référence des données situés dans le CMS : il y a donc un traitement qui compare l'état du doc local par rapport au doc chargé, et qui va déterminer si on doit créer, mettre à jour, ou supprimer des contenus dans mon CMS, et quelles modifications apporter au document pour les prendre en compte (liens). Comme l'utilisateur peut sauver autant de fois qu'il veut, et en particulier pendant que je suis en train de traiter une sauvegarde demandée précédemment, je gère une file d'attente, sous forme de sous-dossiers : à chaque sauvegarde, je fais donc un snapshot du dossier courant vers un sous-dossier dans la file d'attente, ce qui me permet de le traiter tranquillement. Lorsque j'ai fini le traitement, je nettoie le sous-dossier : je supprime les fichiers qui s'y trouvent puis je le supprime et là je dois attendre 90 secondes pour que le dossier, vide, s'efface.

    En debug, je vois que ces 90 secondes d'attente sont effectuées ici :

    WinNTFileSystem.delete0(File) line: not available [native method] [local variables unavailable]	
    WinNTFileSystem(Win32FileSystem).delete(File) line: 504	
    File.delete() line: 871	
    J'ai tenté de faire un rename() également et c'est pareil. Si je kill mon application java pendant le delete(), et que je tente de supprimer mon dossier via l'explorateur windows, c'est pareil. Mais si je ferme mon application avant l'invocation de File.delete(), aucun problème. Si je ferme mon application, et que je la relance, et que je fais un File.delete(), rebelote, 90 secondes d'attente (voir le paragraphe ci-après). Du coup, j'ai du mal à déterminer si le problème vient de java, de windows, de l'utilisation d'un vieux java obsolète avec un windows super récent (genre un effet d'un changement bas niveau dans le traitement des fichiers).

    Je pourrais paralléliser mon traitement d'effacement à la sauvegarde pour éviter de bloquer la sauvegarde, mais j'ai un problème technique pas simple à gérer dans ce cas, car je fais de la reprise à froid (si une des applications plantent, et qu'on redémarre, on retrouve un système stable interconnecté (en particulier la palette flottante) : le problème, c'est que lors des traitements de reprise je suis obligé de supprimer certains dossiers avant de rendre disponible la palette, et il arrive donc que cette dernier ne puisse être disponible qu'au bout de 90 secondes (minimum) après le redémarrage de l'application.

    A noter, que lorsque je teste sous Eclipse, le problème est systématique, alors qu'il est plus rare, lorsque l'application est exécutée buildée.

    J'ai soupçonné au début que c'était windows 8.1 et mon SSD qui posaient problèmes, mais le problème arrive également en production sur des postes windows 7, en disque classique : simplement, ça arrive beaucoup moins souvent, ou seulement lorsque les applications sont fermées dans des états particuliers (comme par exemple, si on laisse une image ouverte dans photoshop, qu'on ferme photoshop, puis qu'on relance l'appli java). J'ai même désactivé l'indexation windows, au cas où (parce que j'avais remarqué avec les outils de sysinternals que l'indexeur windows accédait sans arrêt à mon dossier).

    Aucun problème sur XP, ou encore sur MacOSX.

    Merci par avance de toute idée qui me permettrait d'avancer, parce que j'ai épuisé toutes celles que j'avais pour analyser, corriger ou contourner le problème.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    La première chose à laquelle je penserais, ce serait des verrous sur les dossiers, que ton application réaliserais. Du coup il faut attendre que le verrou "saute" avant que l'effacement puisse avoir lieu. Ce qui serait cohérente avec le fait que tu ne peux pas effacer plus vide "à la main" lorsque ton application est lancée.

    Pourquoi y a des verrous.... mystère, bonne recherche

    Et fait, au risque d'enfoncer une porte ouverte:

    java 5 n'est plus supporté depuis 5 ans (octobre 2009).
    La première relase (alpha) de windows 8 date de 2011....
    La distribution de windows 7 a démarré en octobre 2009

    windows 7 et 8 n'ont jamais même été testé officiellement par oracle avec java 5 je pense

  3. #3
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par tchize_ Voir le message
    La première chose à laquelle je penserais, ce serait des verrous sur les dossiers, que ton application réaliserais. Du coup il faut attendre que le verrou "saute" avant que l'effacement puisse avoir lieu. Ce qui serait cohérente avec le fait que tu ne peux pas effacer plus vide "à la main" lorsque ton application est lancée.
    J'y ai bien pensé, mais personnellement je ne pose pas de verrous explicitement. Reste InDesign ou PhotoShop. Dans la mesure où le problème n'apparait que dans certaines configurations, quelque fois dans d'autres, et jamais dans d'autres, j'ai pensé à un truc bien bas niveau, dans le système, avec une historie de changement d'api et d'incompatibilité, qui fait que java 1.5 caffoullle sur windows 8.

    Citation Envoyé par tchize_ Voir le message
    Pourquoi y a des verrous.... mystère, bonne recherche
    Tout le problème est là. Remarques, je n'ai pas encore essayé de solutions genre exorcistes, désenvouteur ou sorcier vaudou...

    Citation Envoyé par tchize_ Voir le message
    Et fait, au risque d'enfoncer une porte ouverte:

    java 5 n'est plus supporté depuis 5 ans (octobre 2009).
    La première relase (alpha) de windows 8 date de 2011....
    La distribution de windows 7 a démarré en octobre 2009

    windows 7 et 8 n'ont jamais même été testé officiellement par oracle avec java 5 je pense
    Oui, oui, je sais bien. Ca fait bien trois ans que je dis à mes DSI et directeur de projet qu'il faut qu'on migre, mais vu que j'étais charette sur des dévs métiers (et surtout seul), c'était toujours repoussé aux calendes grecques, jusqu'en décembre où le client l'a réclamée. Du coup, j'ai commencé la migration vers 1.7, et là, patatras, bug bloquant sur mac, m'obligeant à maintenir en parallèle les deux versions (sans pouvoir mettre en production la version 1.7), le temps que le bug soit corrigé (il est sur le bugzilla de Eclipse, mais vu comment ça avance, j'ai peur de devoir me coltiner encore la version 1.5 pendant un moment C'est pas le seul problème que j'ai d'ailleurs : d'habitude, je trouve toujours des workarounds, mais là, je sèche.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  4. #4
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Oracle virtualbox, windows Xp

    Oracle extended support (jusque 2015 pour java 5)

Discussions similaires

  1. Les accés disque semblent lents
    Par gifffftane dans le forum Administration système
    Réponses: 32
    Dernier message: 12/03/2009, 22h52
  2. Problème acces disque windows sous linux
    Par stan314 dans le forum Mandriva / Mageia
    Réponses: 15
    Dernier message: 27/08/2006, 19h52
  3. mot de passe pour accés disque dur
    Par david06600 dans le forum Windows XP
    Réponses: 5
    Dernier message: 03/08/2006, 08h32
  4. [MAC + Réseau]Accés disque externe
    Par beho dans le forum Administration
    Réponses: 7
    Dernier message: 05/04/2006, 17h00
  5. Lancement Processus: plus lents depuis java / terminal
    Par Zapan dans le forum Général Java
    Réponses: 7
    Dernier message: 01/02/2006, 20h13

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