Maison >développement back-end >Problème PHP >Comment résoudre un problème de haute concurrence en php ?

Comment résoudre un problème de haute concurrence en php ?

青灯夜游
青灯夜游original
2019-10-12 17:12:468505parcourir

Comment PHP gère-t-il les problèmes de simultanéité élevée lors de l'exécution ? Cet article vous présentera comment PHP résout les problèmes de simultanéité élevée. J'espère qu'il vous sera utile.

Comment résoudre un problème de haute concurrence en php ?

En raison de l'avènement des systèmes distribués, la concurrence élevée (High Concurrency) fait généralement référence à la garantie que le système peut traiter de nombreuses requêtes en parallèle en même temps via conception. En termes simples, une concurrence élevée signifie qu'au même moment, de nombreux utilisateurs accèdent simultanément à la même interface API ou à la même adresse URL. Cela se produit souvent dans des scénarios commerciaux avec un grand nombre d’utilisateurs actifs et une forte concentration d’utilisateurs.

Recommandation de cours vidéo → : "Solution de concurrence de données de niveau dix millions (théorie + combat pratique)"

La logique métier pour gérer une simultanéité élevée est la suivante :

Front-end : requête asynchrone + statique des ressources + cdn

Back-end : file d'attente des requêtes + distribution des interrogations + équilibrage de charge + cache partagé

Couche de données : cache redis + partitionnement de données + file d'attente d'écriture

Stockage : baie raid + veille chaude

Réseau : interrogation DNS + protection contre les attaques DDOS

Quelques façons de résoudre la concurrence élevée en PHP

1. Séparez les applications et les ressources statiques

Placez les ressources statiques (js, css, images, etc.) sur un. milieu de serveur dédié.

2. Mise en cache des pages

La mise en cache des pages générées par l'application peut économiser beaucoup de ressources CPU. Pour certaines pages dont les données changent fréquemment, vous pouvez utiliser ajax pour les traiter.

3. Cluster et

Cluster distribué, plusieurs serveurs ont les mêmes fonctions et jouent principalement le rôle de détournement. Distribué, plaçant différentes entreprises sur différents serveurs, plusieurs serveurs peuvent être nécessaires pour traiter une demande, augmentant ainsi la vitesse de traitement d'une demande. Il est ensuite divisé en cluster de ressources statiques et cluster d'applications. Cette dernière solution est plus compliquée et des problèmes tels que la synchronisation des sessions doivent souvent être pris en compte.

4. Proxy inverse

Le serveur auquel le client accède directement n'est pas le serveur qui fournit directement des services. Il obtient des ressources d'autres serveurs et renvoie ensuite les résultats à l'utilisateur.

Serveur proxy et serveur proxy inverse :

Le serveur proxy accède aux ressources en notre nom et renvoie ensuite les résultats. Par exemple, accédez au serveur proxy du réseau externe. Le serveur proxy inverse est lorsque nous accédons normalement à un serveur, le serveur lui-même appelle d'autres serveurs.

Nous utilisons activement le serveur proxy pour nous servir et n'avons pas besoin d'avoir son propre nom de domaine ; le proxy inverse est utilisé par le serveur lui-même et nous ne savons pas qu'il a son propre nom de domaine.

Pour plus de connaissances sur PHP, veuillez visiter le Site Web PHP chinois !

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
Article précédent:Qu’est-ce que PHP ?Article suivant:Qu’est-ce que PHP ?