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 :

Problème LinkageError loader


Sujet :

Java

  1. #1
    Membre averti
    Inscrit en
    Avril 2010
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 48
    Par défaut Problème LinkageError loader
    Bonjour,

    Je travail actuellement sur un Serveur vocal interactif (SVI).
    Le programme est en JAVA, et tourne sur un IPBX (commutateur téléphonique sur IP).
    J'ai donc mon code source java (SVI.java) que j'ai compilé (SVI.class) sans erreurs

    Ensuite il faut se rendre sur l'IPBX est charger le programme (le fichier .class)
    et c'est la que ça coince

    Problème : Pour tester mon programme, je ne pouvais pas l'appeler SVI.java car il existe déjà un programme nommé SVI actuellement sur l'IPBX.

    J'ai donc décidé de l'appeler autrement (SVIMax.java) et forcement j'ai renommé dans le code ma classe: public class SVI extends AutomataToolkit {......//programme
    }

    par : public class SVIMax extends AutomataToolkit {....
    //programme
    }

    Je compile donc mon fichier SVIMax.java pour obtenir SVIMax.class toujours sans erreurs de compilation (avec javac)


    Ensuite je charge mon programme SVIMax.class sur l'ipbx et là badaboom
    Problème...

    voici le log java de l'IPBX

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    2010/05/03-17:06:51.111 >>>>>>>>>>>>>>>>>>>>> Specific path=false
    2010/05/03-17:06:51.115 [IVR] path=/usr/ipbx/centile/domains/GroupAtribu/GroupCustomization/services
    2010/05/03-17:06:51.115 [IVR] path=/usr/ipbx/IntraSwitch/services
    2010/05/03-17:06:51.125 [IVR] Read prog : SVI
    2010/05/03-17:06:51.140 [IVR] Read prog : SVI 240909
    2010/05/03-17:06:51.141 Throwable error
    java.lang.LinkageError: loader (instance of  com/netergynet/ivr/ivrmotor/FileLoader): attempted  duplicate class definition for name: "SVI"
            at java.lang.ClassLoader.defineClass1(Native Method)
            at java.lang.ClassLoader.defineClass(Unknown Source)
            at java.lang.ClassLoader.defineClass(Unknown Source)
            at com.netergynet.ivr.ivrmotor.FileLoader.findClass(FileLoader.java:261)
            at com.netergynet.ivr.ivrmotor.FileLoader.readProg(FileLoader.java:75)
            at com.netergynet.ivr.ivrmotor.FileLoader.readProg(FileLoader.java:48)
            at com.netergynet.ivr.ivrmotor.IvrPhonelet.readJavaProg(IvrPhonelet.java:717)
            at com.netergynet.ivr.ivrmotor.IvrPhonelet.reloadPath(IvrPhonelet.java:829)
            at com.netergynet.ivr.ivrmotor.IvrPhonelet.startIvr(IvrPhonelet.java:472)
            at com.netergynet.ivr.ivrmotor.IvrPhonelet.init(IvrPhonelet.java:363)
            at com.odisei.server.servicemanager.ServiceManagerImpl.startPhonelet(ServiceManagerImpl.java:2289)
            at com.odisei.server.servicemanager.ServiceManagerImpl.startPhonelets(ServiceManagerImpl.java:2186)
            at com.odisei.server.servicemanager.ServiceManagerImpl.<init>(ServiceManagerImpl.java:484)
            at com.odisei.server.servicemanager.ServiceManagerImpl.main(ServiceManagerImpl.java:1275)
    Alors je me pose la question de savoir d'où peut venir cette erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    java.lang.LinkageError: loader (instance of  com/netergynet/ivr/ivrmotor/FileLoader): attempted  duplicate class definition for name: "SVI"
    Et je ne comprends pas trop cette erreur, j'ai bien importé ma librairie com/netergynet/ivr/ivrmotor lors de la compilation

    Le problème vient-il d'une librairie manquante à la compilation de mon fichier SVIMax?
    ou alors parce que j'ai renommé ma classe SVIMax ?
    ou autre chose encore...

    merci,

  2. #2
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    bonjour,

    ce n'est pas un problème de librairie, mais un problème de chargement de classe alors qu'elle existe deja en memoire.

    at com.netergynet.ivr.ivrmotor.FileLoader.findClass(FileLoader.java:261)

    cette ligne indique que FileLoader est un classLoader.
    Il essai de charger une classe nommé SVI dont la définition existe deja en memoire.
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  3. #3
    Membre averti
    Inscrit en
    Avril 2010
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 48
    Par défaut
    merci pour l'info,

    donc si j'ai bien compris c'est une erreur au niveau de l'IPBX qui essai de charger une classe "SVI" qui existe déjà, et non de mon programme java compilé.

  4. #4
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    oui c'est bien ca, mais cependant ton programme pourrai très bien être la cause de l'erreur car il demande peut être le chargement de SVI !!!

    mais la je ne peux que faire des suppositions sans voir concrètement le code.
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre averti
    Inscrit en
    Avril 2010
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 48
    Par défaut
    En faite actuellement il y a sur l'IPBX le programme SVI.class qui tourne (il est en service en ce moment même).
    Moi j'ai pour tache de modifier (améliorer) ce programme.

    Mais comme c'est un serveur vocal en activité, il est hors de question de le coupé pour faire ma "mise à jour" et tester mon programme.
    En plus si mon programme à un problème il y a un risque de planter l'IPBX

    Il faut donc que je crée mon programme avec un nom différent du premier (SVI) pour qu'ils puissent "cohabiter" sans histoire.

    D'où ma modification pour ce fameux SVIMax.
    Donc j'ai bien mon SVIMax.class que je peux chargé sur l'IPBX.

    La suite tu la connais, j'ai le log avec l'erreur.

    j'ai que 3 lignes de code (qui définissent le temps en second des timeout si aucune instruction n'est enregistré par le programme) qui font appelles à "svi" mais je l'ai modifié comme tu peu le voir

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    private static final String CONFIRMATION_TIMEOUT = System.getProperty("svimax.pressstar.timeout", "5");
    	private static final String DIALNUMBER_TIMEOUT = System.getProperty("svimax.dialnumber.timeout", "10");
    	private static final String GLOBAL_TIMEOUT = System.getProperty("svimax.global.timeout", "1740");

  6. #6
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    Je viens de voir dans la trace de ton 1er post :
    Citation Envoyé par miniRoshan Voir le message
    2010/05/03-17:06:51.125 [IVR] Read prog : SVI --> ca c'est normal
    2010/05/03-17:06:51.140 [IVR] Read prog : SVI 240909 --> c'est ca qui declanche l'erreur !
    Si tu trouves pourquoi il lit deux fois SVI alors tu auras résolut ton problème !
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Membre averti
    Inscrit en
    Avril 2010
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 48
    Par défaut
    je vais me pencher la dessus merci de ton aide.

  8. #8
    Membre averti
    Inscrit en
    Avril 2010
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 48
    Par défaut
    Il semblerai que l'erreur soit bien là.

    en lisant le log on s'aperçoit que l'IPBX charge les mauvais programmes :

    2010/05/03-17:06:51.125 [IVR] Read prog : SVI
    2010/05/03-17:06:51.140 [IVR] Read prog : SVI 240909
    2010/05/03-17:06:51.142 [IVR] Read prog : SVI 250909
    2010/05/03-17:06:51.142 [IVR] Read prog : SVI 280909

    au lieu de charger mon programme SVIMax de test.

    Il doit y avoir une erreur de pointage du répertoire qui exécute les programmes sur l'IPBX.
    Du coup il charge des programmes "déjà chargé" sur la mémoire de l'IPBX d'où l'erreur.

    Il ne reste donc plus qu'a charger le bon programme (SVIMax) en espérant qu'il fonctionne bien

    merci de m'avoir mis sur la bonne voie en tout cas

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

Discussions similaires

  1. [AS2] problème de loader
    Par tutomania dans le forum ActionScript 1 & ActionScript 2
    Réponses: 1
    Dernier message: 27/01/2010, 16h47
  2. Problème pour loader un projet sous Visual Studio 2005
    Par SkyBioSS dans le forum Visual Studio
    Réponses: 5
    Dernier message: 04/04/2008, 16h02
  3. problème SQL LOADER
    Par tigzirt dans le forum SQL*Loader
    Réponses: 1
    Dernier message: 26/12/2007, 18h53
  4. Réponses: 7
    Dernier message: 23/07/2006, 20h01
  5. [FLASH MX 2004] Problème avec loader
    Par Sorento dans le forum Flash
    Réponses: 3
    Dernier message: 06/07/2005, 20h21

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