fork

Autres langues

Langue: fr

Version: 4 septembre 2006 (mandriva - 01/05/08)

Section: 2 (Appels système)

NOM

fork - Créer un processus fils

SYNOPSIS

#include <sys/types.h>
#include <unistd.h>

pid_t fork(void);

DESCRIPTION

fork() crée un nouveau processus en dupliquant le processus appelant. Le nouveau processus, que l'on nomme processus fils, est l'exacte duplication du processus appelant, nommé processus parent, excepté pour les points suivants :
*
Le fils a son propre identifiant de processus (PID). Ce PID est unique et ne correspond à aucun autre identifiant de groupe de processus existant (setpgid(2)).
*
Le PPID (Parent Process ID) du fils est identique au PID du parent.
*
Le fils n'hérite pas des verrouillages mémoire de son parent (mlock(2), mlockall(2)).
*
Les statistiques d'utilisation des ressources de processus (getrusage(2)) et les compteurs de temps CPU (times(2)) sont réinitialisés dans le fils.
*
L'ensemble des signaux en attente pour le fils est initialement vide (sigpending(2)).
*
Le fils n'hérite pas des ajustements de sémaphore de son parent (semop(2)).
*
Le fils n'hérite pas des verrouillages d'enregistrement de son parent (fcntl(2)).
*
Le fils n'hérite pas des temporisateurs de son parent (setitimer(2) alarm(2), timer_create(3)).
*
Le fils n'hérite pas des opérations d'E/S asynchrones en cours de son parent (aio_read(3), aio_write(3)).

Les attributs de processus de la liste précédente sont tous spécifiés dans POSIX.1-2001. Le parent et le fils différent également par les attributs de processus suivant, spécifiques à Linux :

*
Le fils n'hérite pas des notifications de changement de répertoire (dnotify) de son parent (voir la description de F_NOTIFY dans fcntl(2)).
*
L'attribut PR_SET_PDEATHSIG de prctl(2) est réinitialisé de sorte que le fils ne reçoive pas de signal lorsque son parent se termine.
*
Les mappages de mémoire qui ont été marqués avec l'attribut MADV_DONTFORK de madvise(2) ne sont pas hérités à travers un fork(2).
*
Le signal de terminaison du fils est toujours SIGCHLD (voir clone(2)).

Veuillez également noter les points suivants :

*
Le processus fils est créé avec un simple thread --- celui qui a appelé fork(2). L'espace entier d'adresses virtuelles du parent est répliqué dans le fils. Cela inclut les états des mutexes, les variables de condition et autres objects pthreads ; l'utilisation de pthread_atfork(3) peut être préférable afin de gérer les problèmes qui pourraient être provoqués.
*
Le fils hérite d'une copie de l'ensemble des descripteurs de fichiers ouverts du parent. Chaque descripteur de fichier du fils fait référence à la même description de fichier ouvert (voir open(2)) que le descripteur de fichier correspondant du parent. Cela signifie que les deux descripteurs partagent les attributs d'état de fichier ouvert, la position de la tête de lecture et les attributs d'E/S pilotées par signaux (voir la description de F_SETOWN et F_SETSIG dans fcntl(2)).
*
Le fils hérite d'une copie de l'ensemble des descripteurs de files de messages ouverts (voir mq_overview(7)). Chaque descripteur dans le fils fait référence à la même description de file de messages ouverte que le descripteur de file de message ouvert dans le parent. Cela signifie que les deux descripteurs partagent les même drapeaux (mq_flags).

VALEUR RENVOYÉE

En cas de succès, le PID du fils est renvoyé au processus parent, et 0 est renvoyé au processus fils. En cas d'échec -1 est renvoyé dans le contexte du parent, aucun processus fils n'est créé, et errno contient le code d'erreur.

ERREURS

EAGAIN
fork() ne peut pas allouer assez de mémoire pour copier la table des pages du père et une structure de tâche pour le fils.
EAGAIN
Il n'a pas été possible de créer un nouveau processus car la limite ressource RLIMIT_NPROC de l'appelant a été rencontrée. Pour franchir cette limite, le processus doit avoir au moins l'une des deux capacités CAP_SYS_ADMIN ou CAP_SYS_RESOURCE.
ENOMEM
fork() a échoué car le noyau n'a plus assez de mémoire.

CONFORMITÉ

SVr4, BSD 4.3, POSIX.1-2001.

NOTES

Sous Linux, fork() est implementé en utilisant une méthode de copie à l'écriture. Ceci consiste à ne faire la véritable duplication d'une page mémoire que lorsqu'un processus en modifie une instance. Tant qu'aucun des deux processus n'écrit dans une page donnée, celle-ci n'est pas vraiment dupliquée. Ainsi les seules pénalisations induites par fork sont le temps et la mémoire nécessaires à la copie de la table des pages du parent ainsi que la création d'une structure de tâche pour le fils.

EXEMPLE

Voir pipe(2) et wait(2).

VOIR AUSSI

clone(2), execve(2), vfork(2), setrlimit(2), unshare(2), wait(2), capabilities(7), credentials(7)

TRADUCTION

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 9 octobre 1996 et révisée le 27 novembre 2007.

L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 2 fork ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.