Maison  >  Article  >  développement back-end  >  Comprendre le concept, les avantages et les inconvénients de la mémoire partagée PHP

Comprendre le concept, les avantages et les inconvénients de la mémoire partagée PHP

不言
不言original
2018-07-06 15:59:351609parcourir

Cet article présente principalement le concept, les avantages et les inconvénients de la mémoire partagée PHP. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer

La mémoire partagée est une sorte de. Un moyen efficace de partager et de transférer des données entre deux processus en cours d'exécution sur la même machine. La mémoire partagée entre différents processus est généralement organisée comme le même segment de mémoire physique, comme son nom l'indique, la mémoire partagée permet à deux processus non liés d'accéder à la même logique ; mémoire. Un processus peut créer un segment de mémoire accessible à d’autres processus, à condition qu’il dispose des autorisations appropriées. Chaque segment de mémoire possède un identifiant unique (appelé shmid) qui pointe vers une zone de la mémoire physique sur laquelle d'autres processus peuvent opérer. Une fois créés et dotés des autorisations appropriées, d'autres processus sur la même machine peuvent opérer sur ces segments de mémoire : lecture, écriture et suppression. Si un processus écrit des données dans la mémoire partagée, les modifications seront immédiatement affectées. Tout autre processus peut y accéder. le même segment de mémoire partagée.

Cela montre que les applications écrites en C peuvent partager des informations avec des applications écrites dans d'autres langages, comme Java ou PHP. La mémoire partagée est largement utilisée dans les implémentations de la plupart des langages, l'accès ne devrait donc pas poser de problème. Pour comprendre les informations, nous pouvons utiliser un format standard tel que XML ou JSON.

L'utilisation de la mémoire partagée est un moyen rapide d'échanger des données entre processus, principalement parce que les données sont transmises après la création du segment de mémoire, sans impliquer le noyau. Cette méthode est souvent appelée communication inter-processus (IPC). Les autres méthodes IPC incluent les canaux, les files d'attente de messages, le RPC et les sockets. Cette capacité à échanger rapidement et de manière fiable des données entre applications est utile lorsque vous travaillez avec un écosystème d'applications qui doivent communiquer entre elles. En fonction de la taille de l'écosystème, la méthode courante consistant à utiliser une base de données pour échanger des informations entre applications peut souvent entraîner des requêtes lentes, voire un blocage des E/S. Avec la mémoire partagée, aucune E/S ne peut ralentir la progression du développeur.

La mémoire partagée ne fournit pas de mécanisme de synchronisation. C'est-à-dire qu'il n'y a pas de mécanisme automatique pour empêcher le deuxième processus de commencer à le lire avant que le premier processus ait fini d'écrire dans la mémoire partagée. . Nous devons donc généralement utiliser d'autres mécanismes pour synchroniser l'accès à la mémoire partagée.

La proposition de cet article est très simple, apprenez à utiliser PHP pour créer et manipuler des segments de mémoire partagée et utilisez-les pour stocker des ensembles de données pouvant être utilisés par d'autres applications. Même s'il n'est pas prévu d'utiliser la mémoire partagée pour échanger des données, cela présente de nombreux avantages en soi car cela permet aux applications d'éviter les problèmes d'E/S. Le stockage des ensembles de données directement en mémoire présente de nombreux avantages, de la mise en cache des données des services Web au partage de session. C'est un concept très utile que tout développeur PHP devrait connaître.

Avantages et inconvénients de l'utilisation de la mémoire partagée
1.Avantages : Nous pouvons voir que l'utilisation de la mémoire partagée pour la communication inter-processus est vraiment très pratique, et l'interface des fonctions est également simple. Le partage des données élimine également le besoin de transférer des données entre les processus et d'accéder directement à la mémoire, ce qui accélère également l'efficacité du programme. En même temps, cela ne nécessite pas une certaine relation parent-enfant entre les processus communicants comme les tuyaux anonymes.

2. Inconvénients : la mémoire partagée ne fournit pas de mécanisme de synchronisation, ce qui nous oblige souvent à utiliser d'autres moyens pour synchroniser les processus entre les processus lorsque nous utilisons la mémoire partagée pour la communication inter-processus.

Nous pouvons utiliser la mémoire partagée comme une option de stockage unique qui offre des avantages tels que des opérations de lecture/écriture rapides et l'interopérabilité des processus. Pour les applications Web, cela signifie :

Stockage du cache (requêtes de base de données, données du service Web, données externes)
Stockage de session
Échange de données entre applications
Cette technologie de stockage est non seulement utile pour la mise en cache, mais également pour l'échange de données entre applications, à condition que les données soient stockées dans un format lisible par les deux extrémités. Ne sous-estimez pas la puissance de la mémoire partagée dans les applications Web. Il existe de nombreuses façons différentes de mettre en œuvre intelligemment ce stockage, la seule limite étant la créativité et les compétences du développeur.

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !

Recommandations associées :

php utilise simplement la fonction shmop pour créer de la mémoire partagée afin de réduire la charge du serveur

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