Heim > Artikel > Backend-Entwicklung > Wie man zeitaufwändige Aufgaben in PHP erledigt
Wenn der Serverzugriffsdruck relativ hoch ist, können wir den Lastausgleich verwenden, um die Last auf mehrere Server zu verteilen. Es gibt jedoch einige zeitaufwändigere Anforderungen. Zum Beispiel:
1. Sie müssen eine Verbindung zum Mailserver herstellen und eine sehr lange HTML-E-Mail senden. (Empfohlenes Lernen: PHP-Video-Tutorial)
2. Die von Benutzern hochgeladenen Bilder müssen zugeschnitten und mehrere Miniaturansichten generiert werden.
3. Von Benutzern hochgeladene Dateien müssen auf mehrere Server verteilt werden.
In unseren täglichen Anwendungen kommt es häufig vor, dass der Benutzer eine Zeit lang warten muss, bevor die Anfrage abgeschlossen werden kann. Wenn der Benutzer ein Foto hochlädt, wird es nach dem erfolgreichen Hochladen zugeschnitten und Schließlich wird ein Miniaturbild generiert. Während des Vorgangs kann der Benutzer nur warten, sodass die Benutzererfahrung ziemlich schlecht ist.
Vielleicht fällt es dem Benutzer nach der ersten Verwendung schwer, diese Bild-Upload-Funktion das nächste Mal zu verwenden.
Gibt es also eine Möglichkeit, diese Prozesse langsam im Hintergrund laufen zu lassen?
Die Antwort lautet: Ja. Durch die verteilte Verarbeitung können diese zeitaufwändigen Aufgaben in den Hintergrund gestellt oder sogar zur Verarbeitung auf mehrere Server verteilt werden.
Mittlerweile gibt es viele Open-Source-Software, die eine asynchrone Kommunikation erreichen kann, wie ActiveMQ, Hadoop, Gearman und MecacheMQ usw. Sie übertragen Berechnungen geschickt auf andere Server, und das alles ist in der API At versteckt Gleichzeitig sind diese Mechanismen sprachübergreifend. Sie können PHP verwenden, um eine Aufgabe zuzuweisen und diese dann im Hintergrund-C/C++-Programm zu verarbeiten.
Im Folgenden werden PHP und Gearman verwendet, um den asynchronen Verarbeitungsprozess zu demonstrieren.
1. Installation von Gearman
tar zxvf gearmand-0.11.tar.gz cd gearmand-0.11 ./configure --prefix=/usr/local/gearman make make install
2 Gearman PHP-Erweiterung.
tar zxf gearman-0.6.0.tgz cd gearman-0.6.0 phpize ./configure make
Kopieren Sie gearman.so im Modulverzeichnis in das Modulverzeichnis von PHP. Das Verzeichnis meiner Maschine ist /usr/lib/php5/20060613+lfs/.
cp module/gearman.so /usr/lib/php5/20060613+lfs/.
Dann fügen Sie
extension = “gearman.so”
zu php.ini hinzu und starten schließlich die Datei neu Apache-Server.
3. Starten Sie den Gearman-Dienst
cd /usr/local/gearman/sbin ./gearman -d -u root
Der Standardport von Job ist 4730, der mit
[root@serv_1 sbin]# netstat -nl | grep 4730 tcp 0 0 :::4730 :::* LISTEN
gestartet werden kann 🎜>
Pass bin/gearman ist ein Tool, mit dem wir die Funktionen von Gearman erleben können.Worker starten:
./gearman -w -f wc -- wc -l & [1] 2547
Client ausführen :
./gearman -f wc < /etc/passwd 38Im obigen Beispiel ist eine Funktion wc im Worker definiert. Ihre Hauptfunktion besteht darin, die Anzahl der Textzeilen zu zählen. Der Client übergibt den Inhalt der Datei /etc/passwd Abschließend wird festgestellt, dass passwd 38 Textzeilen enthält.
Das obige ist der detaillierte Inhalt vonWie man zeitaufwändige Aufgaben in PHP erledigt. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!