CIX. Sémaphores et gestion de la mémoire partagée

Introduction

Ce module fourni un système de sémaphore. Ce système utilise les sémaphores System V.

Les sémaphores peuvent être utilisés pour fournir un accès exclusif à certaines ressources de la machine, ou pour limiter le nombre de processus qui utilisent en même temps une ressource.

Ce module fournit aussi un système de mémoire partagée, qui utilise la mémoire partagée System V. Cette mémoire partagée permet d'accéder à des variables globales. Les différents démons httpd et mêmes d'autres programmes (tels que Perl, C, ...) permettent un tel échange de données global. N'oubliez pas que la mémoire partagée n'est pas protégées contre l'accès simultané. Il vous faudra utiliser les sémaphores pour assurer la synchronisation.

Tableau 1. Limites de la mémoire partagée sous Unix OS

SHMMAX Taille maximale de mémoire partagée, par défaut, 131072 octets.
SHMMIN Taille minimale de mémoire partagée, par défaut, 1 octet.
SHMMNI Nombre maximal de segment de mémoire partagé, par défaut 100.
SHMSEG Taille maximale de mémoire partagée par processus, par défaut 6.

Ces fonctions permettent d'envoyer et de recevoir des messages de/vers d'autres processus. Elles offrent une interface simple et efficace pour échanger des données entre processus, sans avoir besoin d'utiliser un autre sockets UNIX.

Note : Cette extension n'est pas disponible sur les plates-formes Windows.

Pré-requis

Ces fonctions sont disponibles dans le module PHP standard, qui est toujours accessible.

Installation

Le support de ces fonctions n'est pas activé par défaut. Pour activer le support des sémaphores System V, compilez PHP avec l'option --enable-sysvsem. Pour activer le support de la mémoire partagée System V, compilez PHP avec l'option --enable-sysvshm. Pour activer le support des messages System V, compilez PHP avec l'option --enable-sysvmsg.

Configuration à l'exécution

Le comportement de ces fonctions est affecté par la configuration dans le fichier php.ini.

Tableau 2. Options de configuration

NomPar défautModifiable
sysvmsg.value"42"PHP_INI_ALL
sysvmsg.string"foobar"PHP_INI_ALL
Pour plus de détails sur les constantes PHP_INI_*, reportez-vous à ini_set().

Constantes pré-définies

Ces constantes sont définies par cette extension, et ne sont disponibles que si cette extension a été compilée avec PHP, ou bien chargée au moment de l'exécution.

Tableau 3. Constantes des messages System V

ConstanteType
MSG_IPC_NOWAITentier
MSG_NOERRORentier
MSG_EXCEPTentier

Table des matières
ftok --  Convertit un chemin et un identifiant de projet en une clé System V IPC
msg_get_queue --  Crée ou s'attache à une file de message
msg_receive --  Reçoit un message depuis une file de messages
msg_remove_queue --  Détruit une file de messages
msg_send --  Envoie un message dans une file
msg_set_queue --  Modifie des informations dans la file de messages
msg_stat_queue --  Retourne des informations sur la file de messages
sem_acquire -- Réserve un sémaphore
sem_get -- Retourne un identifiant de sémaphore
sem_release -- Libère un sémaphore
sem_remove -- Détruit un sémaphore
shm_attach --  Crée ou ouvre un segment de mémoire partagée
shm_detach -- Libère un segment de mémoire partagée
shm_get_var --  Lit une variable dans la mémoire partagée
shm_put_var --  Insère ou modifie une variable de la mémoire partagée
shm_remove_var --  Efface une variable de la mémoire partagée
shm_remove --  Supprime un segment de mémoire partagée sous Unix