Heim  >  Artikel  >  Backend-Entwicklung  >  Zusammenfassung des Schreibens von Back-End-Laufprogrammen in PHP

Zusammenfassung des Schreibens von Back-End-Laufprogrammen in PHP

巴扎黑
巴扎黑Original
2016-11-23 14:42:411851Durchsuche

1. Regelmäßig ausführen

Einfach crontab, Linux-Befehl, wie man es benutzt, googeln Sie es selbst. Ich möchte nur sagen, dass Sie bei der Verwendung von crontab auf Berechtigungen achten müssen. Der Betrieb und die Wartung verwenden häufig Root, um zu starten, was dazu führt, dass Webbenutzer für einige Dateien keine Berechtigungen haben.

2. Hintergrundschutz

Es gibt zwei Schritte: 1. Sie müssen eine Endlosschleife in das Skript schreiben, da PHP normalerweise nicht mit Python vergleichbar ist. while (true); Es ist jedoch im Allgemeinen erforderlich, einen Schlaf innerhalb des Schleifenkörpers hinzuzufügen. 2. Wenn Sie den Prozess starten, müssen Sie am Ende ein „&“ hinzufügen Wenn Sie die Ausgabeinformationen aufzeichnen müssen, müssen Sie php xxxx so schreiben, dass die Programminformationen in der Datei aufgezeichnet werden, um die Fehlerbehebung in Zukunft zu erleichtern.

3. Betriebsüberwachung

Der Hintergrund-Daemon-Prozess wird gestartet, Sie können jedoch nicht 100 % sicher sein, dass Ihr Programm keine Warnmeldungen anzeigt. Sobald diese Meldungen angezeigt werden, beendet PHP den aktuellen Prozess . Zu diesem Zeitpunkt wird das Hintergrundprogramm direkt beendet. Zusätzlich zu dem Programm, das die Dinge normal erledigt, benötigen Sie auch ein Programm, das den Ausführungsstatus dieses Programms überprüft. Ich nenne es normalerweise xxxxDefend.php. Ein Beispiel für dieses Programm ist wie folgt:

#!/ usr/local/php5/bin/php

//Startbefehl
$action = '/usr/local/php5/bin/php xxxxxx.php';
$logPath = '/tmp/ logs/';


do {
$result = array();
exec("ps aux | grep 'xxxxxx.php'", $result);

$isOk = 0;
foreach ($result as $v) {
$is = strpos($v, $action);
if (false != = $is) {
$isOk ;
}

$exec = $action . " > " . "xxxxxx_log &";

für ($ i=1;$i<= (5-$isOk);$i ) {
exec($exec);
}
sleep(5);
} while (true);

Stellen Sie dieses Programm in den Hintergrund und überprüfen Sie alle 5 Sekunden mit dem Befehl ps, ob die Arbeitsprogramme vorhanden sind. Wenn sie nicht vorhanden sind oder weniger als 5 vorhanden sind, wird es gestartet 5. Natürlich kann diese Arbeit auch der Bedienung und Wartung über die Shell überlassen werden, aber wenn die Bedienungs- und Wartungsfunktionen nicht ausreichen, müssen Sie sie selbst erledigen.

4. Multiprozess

Um die Effizienz zu steigern, startet funktionierendes PHP normalerweise mehrere Prozesse gleichzeitig oder läuft sogar auf mehreren Maschinen. Zu diesem Zeitpunkt müssen wir das Problem berücksichtigen, dass mehrere Prozesse gleichzeitig dieselben Daten verarbeiten. Zu diesem Zeitpunkt erstelle ich normalerweise eine Warteschlange für die Aufgaben (normalerweise verwende ich Redis, das eine ziemlich gute Leistung bietet. Wie das geht, können Sie bei Google nachschlagen), und dann zeigt das Arbeitsprogramm jedes Mal einen Datensatz an, an dem gearbeitet werden soll. Wenn Sie beispielsweise eine große Datei verarbeiten müssen, verarbeite ich die Dateien normalerweise einzeln und füge sie einzeln in die Redis-Liste ein, sodass das Arbeitsprogramm von mehreren Programmen gleichzeitig geöffnet werden kann parallel und ohne Duplikate ausgeführt werden. Wenn Sie wirklich nicht über Redis verfügen, können Sie mit MySQL eine Innodb-Tabelle erstellen. Bevor das Programm die Daten verarbeitet, müssen Sie den zu verarbeitenden Daten unbedingt eine Lesesperre hinzufügen und nach der Verarbeitung oder direkt eine Markierung hinzufügen Löschen Sie die Daten. Dies kann auch erreicht werden. Das Problem der Nichtduplizierung in mehreren Prozessen.

5. Protokoll

Das Hintergrundprogramm wird im Allgemeinen weiterlaufen, es sei denn, etwas schief geht, daher ist das Protokoll äußerst wichtig, denn sobald etwas schief geht, brauchen Sie es Sich auf das Protokoll zu verlassen, um den Grund zu finden. Ja, im Gegensatz zum Front-End-Programm, das ein Echo durchführen kann, um zu sehen, wo der Fehler liegt. Haben Sie keine Angst davor, zu viel zu protokollieren oder Speicherplatz zu verschwenden. Festplatten sind wertlos, aber ein Fehler kann sich direkt auf Ihr Einkommen auswirken. Normalerweise führe ich Protokolle wie dieses

[Maschinen-IP] [Prozess-PID] [Zeit] [aktueller Programmdateiname] [Anzahl der Dateizeilen] [erforderliche Parameter und Informationen] [Sonstiges]

Dies ist ein Problem, das in normalen Programmen zu erwarten ist. Im Allgemeinen wird der äußersten Ebene des Programms ein Try-Catch hinzugefügt, sodass die meisten Ausnahmen abgefangen und dann aufgezeichnet werden können (der Warn-Catch kann nicht abgefangen werden, was ziemlich frustrierend ist). )

6. Leistungsoptimierung

Bei Hintergrundprogrammen wie diesem werden Betrieb und Wartung im Allgemeinen separat für die Maschine durchgeführt. Zu diesem Zeitpunkt muss ein Stresstest durchgeführt werden, um zu sehen, wie Wenn Sie mit der Verarbeitung von Aufgaben beschäftigt sind, überprüfen Sie am besten die CPU-, Speicher-, Netzwerk- und Festplattenauslastung Damit Ihre Maschine nicht verschwendet wird, ist die Auslastung anderer Festplatten sehr gering. In diesem Fall werden die gelesenen und geschriebenen Daten normalerweise vorübergehend im Speicher gespeichert Für einen bestimmten Zeitraum und dann auf die Festplatte geschrieben, bedeutet dies, dass Ihr Algorithmus zu unordentlich ist. PHP verbraucht im Allgemeinen nicht viel Speicher und der Server muss mindestens über eine Gigabit-Netzwerkkarte verfügen. Diese beiden Elemente stellen im Allgemeinen keine Engpässe dar. Daher öffne ich normalerweise einen Memcache auf diesen Maschinen, haha, keine Verschwendung.

7. Exkurs

Eine Frage zum Server close_wait. PHP-Programmierer gehen im Allgemeinen nicht sehr streng vor, um die Verbindung nach dem Öffnen des Links zu schließen. Viele Programmierer erstellen beispielsweise den Link, betreiben ihn und führen dann das Programm aus vollendet. Wenn PHP die Verbindung nicht aktiv schließt, wartet der Computer der anderen Partei immer auf den Schließvorgang. Auf dem Server der anderen Partei wird ein close_wait-Status angezeigt, und ein Computer kann nur mehr als 60.000 Links öffnen, insbesondere nach dem Hintergrundprogramm anfing zu laufen, die Maschine der anderen Partei war schnell voll und konnte nicht angeschlossen werden. Zu diesem Zeitpunkt müssen beide Seiten einige Änderungen vornehmen. Einerseits muss PHP die Verbindung aktiv trennen, und andererseits muss der Computer der anderen Partei das Standard-Timeout von close_wait ändern, um es kürzer zu machen (wie kann man es ändern? Googeln Sie es selbst. Normalerweise verwende ich Memcache nur 5 Sekunden, die Datenbank dauert länger, nämlich 2 Minuten. Nach dieser Verarbeitung wird die Kontinuität des Servers erheblich erhöht und auch die Parallelitätsfähigkeit verbessert.


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