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

POSIX C Discussion :

Plantage dans un thread fils


Sujet :

POSIX C

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut Plantage dans un thread fils
    bonjour,

    J'ai déjà posté ça dans le forum windows mais je crois que ce sera plus à sa place ici...

    J'ai une appli qui est un service windows et qui doit lancer plusieurs threads (librairie pthread utilisée) en fonction de demandes extérieures, chacun d'entre eux pouvant effectuer des taches différentes.

    En fait, le prog principal scrute une base de données et lorsqu'il y trouve certaines valeurs, il lance un nouveau thread qui doit effectuer une fonction.

    Lorsque l'un des threads en cours crashe (access violation par exemple), tout mon service plante et il ne peut plus prendre les nouvelles demandes.

    Y a t il un moyen pour que le programme principal continue de tourner même si l'un des threads qu'il a lancé plante?

    Merci de votre aide.

  2. #2
    Membre émérite Avatar de nicolas.sitbon
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2 015
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2 015
    Points : 2 280
    Points
    2 280
    Par défaut
    c'est possible en catchant le signal SIGSEGV mais ça ne résoudrait en rien le problème, donc ça n'est pas une solution, tu dois trouver la raison de cette violation mémoire et la corrigé.

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut
    Merci pour ta réponse mais résoudre la violation ne répond pas à mon problème.

    Je veux multi threader mon appli justement pour qu'elle puisse continuer à servir des demandes même si l'une d'entre elle crashe...

    Peux-tu m'en dire plus sur le catch du signal SIGSEGV stp?

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 381
    Points : 41 582
    Points
    41 582
    Par défaut
    Note: Le multipost est assez mal vu sur ce forum...

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Note: Le multipost est assez mal vu sur ce forum...

    Désolée pour ça. Je l'ai dit au début de celui-ci que ce post me semblait plus à sa place ici. Et comme je ne peux pas supprimer l'autre....

    Citation Envoyé par Médinoc
    Eh bien, tu peux toujours utiliser du Structured Exception Handling (SEH) pour capter l'Access Violation dans le thread, mais pour un service, surtout s'il tourne en localsystem, je le déconseille fortement: Le plantage d'un thread est signe que quelque chose est corrompu, et rien ne prouve que ça ne va pas perturber le reste.
    Je conseillerais plutôt de régler les paramètres de redémarrage automatique du service plutôt que laisser tourner un service dont l'un des threads a fait une Access Violation...
    Je sais bien que ne pas avoir de violation serait la meilleure solution. Mais ce n'est pas la solution que je recherche.
    Je vais regarder du côté SEH. Merci pour cette piste.

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 381
    Points : 41 582
    Points
    41 582
    Par défaut
    Dans ce cas, assure-toi que ton service ne tourne pas en LocalSystem : Cet utilisateur a tous les droits et tous les privilèges, donc il ne faut surtout pas le laisser tourner avec de la mémoire corrompue...

  7. #7
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 306
    Points
    5 306
    Par défaut
    De toute facon, SIGSEGV n'est pas implémenté sou Windows NT

    En C / Windows, il ne reste plus que les SEH (__try et __except(EXCEPTION_EXECUTE_HANDLER)).

    Mais pourquoi tu ne creuses pas plus l'origine des crashs au lieu d'essayer de mettre un pansement dessus ?

  8. #8
    Membre émérite Avatar de nicolas.sitbon
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2 015
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2 015
    Points : 2 280
    Points
    2 280
    Par défaut
    Citation Envoyé par vicenzo Voir le message
    De toute facon, SIGSEGV n'est pas implémenté sou Windows NT

    En C / Windows, il ne reste plus que les SEH (__try et __except(EXCEPTION_EXECUTE_HANDLER)).

    Mais pourquoi tu ne creuses pas plus l'origine des crashs au lieu d'essayer de mettre un pansement dessus ?
    Je croyais que l'implémentation microsoft était conforme C90? Si c'est bien le cas, il y a le support de SIGSEGV.

  9. #9
    Rédacteur
    Avatar de Vincent Rogier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 373
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 373
    Points : 5 306
    Points
    5 306
    Par défaut
    Citation Envoyé par nicolas.sitbon Voir le message
    Je croyais que l'implémentation microsoft était conforme C90? Si c'est bien le cas, il y a le support de SIGSEGV.
    NON... Voir sur MSDN : signal(CTR)

    Extrait :

    The SIGILL, SIGSEGV, and SIGTERM signals are not generated under Windows NT. They are included for ANSI compatibility. Thus you can set signal handlers for these signals with signal, and you can also explicitly generate these signals by calling raise.
    La norme C impose que les signaux SIGABRT, SIGFPE, SIGILL, SIFINT SIGSEGV et SIGTERM soit définis mais n'impose pas à l'implémentation de les générer...

  10. #10
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 381
    Points : 41 582
    Points
    41 582
    Par défaut
    Pourtant, le code de la CRT de Visual 2005 montre qu'elle est faite pour transformer une Access Violation non-gérée en "pseudo-SIGSEGV" (elle appelle le handler de SIGSEGV dans son SEH Exception filter pour EXCEPTION_ACCESS_VIOLATION)...

    Edit: Confirmé par la version 2005 de la doc de signal(). La prise en charge de SIGSEGV est donc une nouveauté de Visual 2005...

  11. #11
    Membre à l'essai
    Profil pro
    Inscrit en
    Août 2004
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2004
    Messages : 35
    Points : 20
    Points
    20
    Par défaut
    Aprés quelques essais rapides, l'utilisation de SEH semble convenir pour ce que je veux faire.
    Merci pour votre aide. Je passe le sujet à résolu.

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

Discussions similaires

  1. [JFileChooser] plantage aléatoire dans un Thread séparé
    Par RR instinct dans le forum Agents de placement/Fenêtres
    Réponses: 3
    Dernier message: 24/07/2009, 13h53
  2. Plantage dans un thread fils
    Par stehga dans le forum Windows
    Réponses: 2
    Dernier message: 14/05/2008, 20h51
  3. [Process]Execution de process dans un thread
    Par devjava dans le forum Concurrence et multi-thread
    Réponses: 5
    Dernier message: 18/06/2004, 10h34
  4. erreur d'un timer declaré dans un thread
    Par hak5 dans le forum C++Builder
    Réponses: 2
    Dernier message: 03/04/2004, 09h20
  5. Gestion des message windows dans les threads
    Par billyboy dans le forum Windows
    Réponses: 5
    Dernier message: 06/10/2003, 17h25

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