Heim >Backend-Entwicklung >PHP-Problem >Wie löse ich ein Problem mit hoher Parallelität in PHP?

Wie löse ich ein Problem mit hoher Parallelität in PHP?

青灯夜游
青灯夜游Original
2019-10-12 17:12:468505Durchsuche

Wie geht PHP mit Problemen mit hoher Parallelität um? In diesem Artikel erfahren Sie, wie PHP Probleme mit hoher Parallelität löst.

Wie löse ich ein Problem mit hoher Parallelität in PHP?

Aufgrund des Aufkommens verteilter Systeme bezieht sich hohe Parallelität (High Concurrency) normalerweise darauf, sicherzustellen, dass das System viele Anforderungen gleichzeitig gleichzeitig verarbeiten kann Design. Für Laien bedeutet hohe Parallelität, dass viele Benutzer gleichzeitig auf dieselbe API-Schnittstelle oder URL-Adresse zugreifen. Es tritt häufig in Geschäftsszenarien mit einer großen Anzahl aktiver Benutzer und einer hohen Benutzerkonzentration auf.

Videokursempfehlung →: "Zehn-Millionen-Level-Daten-Parallelitätslösung (Theorie + Praxis)"

Die Geschäftslogik für den Umgang mit hoher Parallelität ist:

Front-End: asynchrone Anfrage + Ressourcenstatik + CDN

Back-End: Anforderungswarteschlange + Abfrageverteilung + Lastausgleich + Gemeinsamer Cache

Datenschicht: Redis-Cache + Daten-Sharding + Schreibwarteschlange

Speicher: RAID-Array + Hot-Standby

Netzwerk: DNS-Abfrage + DDOS-Angriffsschutz

Einige Möglichkeiten zur Lösung hoher Parallelität in PHP

1. Trennen Sie Anwendungen und statische Ressourcen

Platzieren Sie statische Ressourcen (JS, CSS, Bilder usw.) auf einem dedizierter Server Mitte.

2. Seiten-Caching

Das Caching der von der Anwendung generierten Seiten kann viele CPU-Ressourcen einsparen. Für einige Seiten, auf denen sich häufig Daten ändern, können Sie diese mit Ajax verarbeiten.

3. Cluster und verteilt

Cluster, mehrere Server haben die gleichen Funktionen und spielen hauptsächlich die Rolle der Umleitung. Verteilt, wodurch verschiedene Unternehmen auf verschiedenen Servern untergebracht werden können, um eine Anfrage zu verarbeiten, wodurch die Verarbeitungsgeschwindigkeit einer Anfrage erhöht wird. Es ist weiter in statische Ressourcencluster und Anwendungscluster unterteilt. Letzteres ist komplizierter und häufig müssen Probleme wie die Sitzungssynchronisierung berücksichtigt werden.

4. Reverse-Proxy

Der Server, auf den der Client direkt zugreift, ist nicht der Server, der direkt Dienste von anderen Servern erhält und die Ergebnisse dann an den Benutzer zurückgibt.

Proxyserver und Reverse-Proxyserver:

Der Proxyserver greift in unserem Namen auf Ressourcen zu und gibt dann die Ergebnisse zurück. Greifen Sie beispielsweise auf den Proxyserver des externen Netzwerks zu. Wenn wir normalerweise auf einen Server zugreifen, ruft der Server selbst einen anderen Server auf.

Wir nutzen den Proxy-Server aktiv für unsere Zwecke und benötigen keinen eigenen Domänennamen. Der Reverse-Proxy wird vom Server selbst verwendet und wir wissen nicht, dass er einen eigenen Domänennamen hat.

Weitere PHP-bezogene Kenntnisse finden Sie auf der PHP-Chinese-Website!

Das obige ist der detaillierte Inhalt vonWie löse ich ein Problem mit hoher Parallelität in PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:Was ist PHP?Nächster Artikel:Was ist PHP?