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 :

IPC : pipe() ou SysV IPC ?


Sujet :

POSIX C

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 10
    Par défaut IPC : pipe() ou SysV IPC ?
    Bonjour à tous,

    Avant tout, j'espère ne pas me tromper de forum.

    Le contexte :
    Un processus parent qui fork() à certains moments. Le processus fils doit remonter au père un flot de données, potentiellement volumineux.

    Je cherche donc à savoir, au niveau performance, ce qui est le mieux entre utiliser un pipe() entre les deux process, ou bien un segment de mémoire partagée + sémaphores ?

    Si les données sont échangées en une seule fois entre le père et le fils, j'imagine qu'un segment de mémoire partagée doit être plus rapide, par contre dans le cas où les données sont échangées en plusieurs flots, il y aura donc plusieurs appels à semop(), aussi bien chez le fils que le père, et peut-être que dans ce cas le pire serait plus efficient non ?

    Et sinon une autre idée, faire passer les données via une socket, c'est le même principe qu'un pipe (au niveau implementation sur l'os) ? Est-ce plus efficient ?

    Si vous avez d'autres idées (surement meilleures) je suis preneur. Par contre il me faut impérativement faire du multiprocess, pas de threads.

  2. #2
    Membre émérite
    Avatar de D[r]eadLock
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    504
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 504
    Par défaut
    Citation Envoyé par Sebou Voir le message
    Et sinon une autre idée, faire passer les données via une socket, c'est le même principe qu'un pipe (au niveau implementation sur l'os) ? Est-ce plus efficient ?
    À mon avis (qui vaut ce qu'il vaut) la mémoire partagée sera plus efficace, car avec les pipes, tu passe par le system et il y a de la recopie (quoique, avec les socket packet (du moins sous Linux, avec le noyau correctement configuré), il y moyen de passer par de la mémoire mappée).
    Conclusions, des benchs s'imposent (soit à faire, soit à chercher...)

Discussions similaires

  1. SYSV IPC vs SOCKET
    Par kilou dans le forum Applications et environnements graphiques
    Réponses: 0
    Dernier message: 10/10/2007, 13h33
  2. [IPC: Anonymous pipe] nombre de bytes
    Par ZaaN dans le forum Visual C++
    Réponses: 4
    Dernier message: 11/07/2007, 09h47
  3. [IPC: anonymous pipe] mauvais HANDLE
    Par ZaaN dans le forum Visual C++
    Réponses: 4
    Dernier message: 06/02/2007, 09h41
  4. [IPC: anonymous pipe] fonctionnement
    Par ZaaN dans le forum MFC
    Réponses: 4
    Dernier message: 30/01/2007, 08h29
  5. [EJB] Local Interface et IPC
    Par trolldom dans le forum Java EE
    Réponses: 2
    Dernier message: 10/11/2005, 18h33

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