Maison  >  Article  >  développement back-end  >  Utilisation de la mémoire partagée PHP et exemple d'analyse du contrôle du signal

Utilisation de la mémoire partagée PHP et exemple d'analyse du contrôle du signal

不言
不言original
2018-05-09 10:22:451137parcourir

Cet article présente principalement l'analyse des exemples d'utilisation de la mémoire partagée PHP et de contrôle du signal. Il a une certaine valeur de référence. Maintenant, je le partage avec tout le monde. Les amis dans le besoin peuvent s'y référer

Les exemples de cet article. décrire le partage PHP. Utilisation de la mémoire et contrôle du signal. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Mémoire partagée

L'utilisation de la mémoire partagée vise principalement à permettre différents les utilisateurs doivent utiliser la même machine. Certaines données sont partagées entre les processus, comme l'utilisation du processus actuel entre plusieurs processus php-fpm. Ce type de communication est également appelé Inter-Process Communication, ou IPC en abrégé.

L'extension shmop (Shared Memory Operations) intégrée à PHP fournit une série de fonctions pour les opérations en mémoire partagée (peut-être parce que peu de gens l'utilisent, ce document n'a pas encore été traduit en chinois). Sous Linux, ces fonctions sont directement implémentées en appelant la série de fonctions shm*, tandis que sous Winodows, les mêmes appels sont également implémentés en encapsulant des fonctions système.

Fonctions principales :

shmop_close — ferme le bloc de mémoire partagée

shmop_delete — supprime le bloc de mémoire partagée

shmop_open — Créer ou ouvrir un bloc de mémoire partagée

shmop_read — Lire les données d'un bloc de mémoire partagée

shmop_size — Obtenez la taille du bloc de mémoire partagée

shmop_write — Écrivez des données dans le bloc de mémoire partagée

Il y a une autre chose importante liée à cette fonction : ftok, crée la clé unique d'IPC via les informations d'inode du fichier (visualisées via la commande stat ou ls -i sur *nix) (l'inode du fichier/dossier est unique). Cette fonction est également implémentée en appelant directement la fonction système du même nom sous Linux, et une certaine encapsulation est toujours utilisée sous Windows.

Un exemple de comptage simple :

<?php
# 创建一块共享内存
$shm_key = ftok(__FILE__, &#39;t&#39;);
$shm_id = shmop_open($shm_key, &#39;c&#39;, 0644, 8);
# 读取并写入数据
$count = (int) shmop_read($shm_id, 0, 8) + 1;
shmop_write($shm_id, str_pad($count, 8, &#39;0&#39;, STR_PAD_LEFT), 0);
// echo shmop_read($shm_id, 0, 8);
# 关闭内存块,并不会删除共享内存,只是清除 PHP 的资源
shmop_close($shm_id);

Le code ci-dessus n'exécute pas le décompte plus 1 une fois, et les données sont dans un processus différent partagé entre. Autrement dit, à moins que cette mémoire ne soit supprimée manuellement, ces données ne seront pas réinitialisées.

Il y a quelque chose à noter : le deuxième paramètre de shmop_open est un drapeau, similaire au deuxième paramètre de fopen, et ses valeurs sont les précédentes :

"a" read- Accès uniquement ;

"c" Si le segment de mémoire n'existe pas, créez-le, s'il existe, il peut être lu et écrit

"w" lire et écrire

;

"n" create Si un nouveau segment de mémoire avec la même clé existe déjà, la création échouera dans un souci d'utilisation sûre de la mémoire partagée.

De plus, comme le segment de mémoire partagée utilisé est de longueur fixe, la longueur des données doit être calculée lors du stockage et de la lecture, sinon l'écriture risque d'échouer ou une valeur nulle peut être lue.

Contrôle du signal

Étant donné que la mémoire partagée est utilisée pour stocker les données ci-dessus, vous devez déterminer si plusieurs processus écrivent des données dans la mémoire partagée en même temps, les circonstances, si les conflits doivent être évités. Si tel est le cas, vous devez introduire un sémaphore pour le contrôle.

PHP fournit également une extension intégrée similaire sysvsem (cette extension n'est pas disponible dans l'environnement Windows. La fonction ftok est également incluse dans cette extension dans le document, mais en fait ftok est fournie dans la fonction standard bibliothèque, donc également disponible sous Windows).

Avant de parler de contrôle des sémaphores, laissez-moi parler d'une autre chose intéressante : en regardant la documentation officielle, vous constaterez qu'il existe également des fonctions pour les opérations de mémoire partagée (shm_*), car ce sont en fait la même catégorie (ou trois extensions du même auteur) et une est sysvmsg (file d'attente des messages). La mise en œuvre des fonctions est légèrement différente, mais ce qu’elles font réellement est fondamentalement le même. Quelle est la différence entre ceci et l’extension shmop ci-dessus ? Le fichier README sous le code source de shmop a une description simple :

PHP avait déjà une extension de mémoire partagée (sysvshm) écrite par Christian Cartus 32982644a4ae8a6ce575374773bddd52, malheureusement cette extension a été conçue avec PHP uniquement à l'esprit et offre des fonctionnalités de haut niveau extrêmement gênantes pour le SHM de base que nous avions en tête. Les paramètres sont d'abord sérialisés à l'aide de la fonction de sérialisation variable de PHP, puis stockés. Cela signifie que les données stockées via ces méthodes ne peuvent pas être partagées avec des processus non PHP. Cependant, cela peut également stocker des types de données PHP plus riches. Dans l'extension ci-dessus, shmop_write ne peut écrire que des chaînes. Alors pourquoi sysvshm ne prend-il pas également en charge Windows ? Parce qu'il n'introduit pas le fichier d'en-tête de tsrm_win32.h qui encapsule la série de fonctions shm*.

Exemple après introduction du contrôle de signal :

<?php
$id_key = ftok(__FILE__, &#39;t&#39;);
$sem_id = sem_get($id_key);
# 请求信号控制权
if (sem_acquire($sem_id)) {
  $shm_id = shmop_open($id_key, &#39;c&#39;, 0644, 8);
  # 读取并写入数据
  $count = (int) shmop_read($shm_id, 0, 8) + 1;
  shmop_write($shm_id, str_pad($count, 8, &#39;0&#39;, STR_PAD_LEFT), 0);
  // echo shmop_read($shm_id, 0, 8);
  # 关闭内存块
  shmop_close($shm_id);
  # 释放信号
  sem_release($sem_id);
}
Mais il est en réalité très difficile de simuler localement des conflits d'écriture (compte tenu de la vitesse d'exécution de l'ordinateur). Dans le test local, si vous n'utilisez pas shmop_close pour fermer la ressource lors de l'utilisation d'une opération de boucle for, une erreur avertissant que la mémoire partagée ne peut pas être ouverte apparaîtra. Cela peut être dû au fait que la mémoire partagée est occupée par l'opération précédente et n'a pas encore été libérée.

Recommandations associées :

Comment implémenter les fonctions de la série shmop à l'aide de la mémoire partagée PHP

Introduction détaillée au code utilisé par la mémoire partagée PHP


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn