


Wie löste ich den Hintergrund asynchroner Stapel -Senden von SMS -Nachrichten im Vordergrund aus, ohne die Benutzererfahrung zu beeinflussen?
In diesem Artikel wird vorgestellt, wie das Front-End aktiviert werden kann, um den Hintergrund auszulösen, um Textnachrichten in Stapeln zu senden, ohne die Benutzererfahrung zu beeinflussen. Nachdem der Benutzer auf die Schaltfläche geklickt hat, gibt die Rezeption sofort die Erfolgsaufforderung zurück, und der Back Desk führt Datenbankabfrage, Redis -Cache -Schreiben und SMS asynchron aus.
Kernidee: Asynchrone Verarbeitung
Diese Lösung verwendet einen asynchronen Verarbeitungsmechanismus, um zeitaufwändige Operationen in den Hintergrund zu verschieben, um die Durchführung zu ermöglichen und zu vermeiden, dass der Vordergrund blockiert wird. Die spezifischen Schritte sind wie folgt:
-
Front-End AJAX-Anfrage: Der Benutzer klickt auf die Schaltfläche Senden, und das Front-End verwendet AJAX, um eine Anfrage an den Hintergrund zu senden. Die Anforderungsparameter enthalten die SMS -Vorlagen -ID, die Liste der Mobiltelefonnummer und die SMS -Inhalte.
$ .ajax ({{{ URL: '/sendsms', Typ: 'Post', Daten: {template_id: 123, Mobile: ['13800138000', '13800138001'], Inhalt: 'test sms'}, Erfolg: Funktion (Antwort) { ALERT ('SMS -Sendungsanfrage wurde eingereicht'); }, Fehler: Funktion (Fehler) { alert ('Anfrage fehlgeschlagen:' error.responseText); } });
Nach dem Login kopieren -
Der Hintergrund empfängt die Anfrage und gibt die Antwort zurück: Nachdem der Hintergrund die AJAX-Anfrage erhalten hat, gibt er sofort eine erfolgreiche Antwort (JSON-Format) zurück, um das Front-End zu informieren, dass die Anfrage eingegangen ist. Der Schlüssel ist, dass die Send -Sendungslogik in eine asynchrone Aufgabe aufgenommen wird.
// Hintergrund -Controller -Methode öffentliche Funktion sendsmsAction () { $ templateId = $ _post ['template_id']; $ mobiles = $ _post ['Mobiles']; $ content = $ _post ['content']; // Die erfolgreiche Antwort gibt sofort JSON_Encode zurück (['Erfolg' => true, 'message' => 'Anforderung empfangen, SMS -Sendenaufgabe gestartet']); // Aufgaben zu Warteschlangen hinzufügen (z. B. mit Redis oder Rabbitmq) $ this-> addtaskToqueue ($ templateId, $ mobiles, $ content); }
Nach dem Login kopieren -
Asynchronous Task Processing:
addTaskToQueue
-Methode fügt der Meldungswarteschlange SMS -Sendeaufgaben hinzu. Ein unabhängiger Hintergrundprozess (beispielsweise unter Verwendung von Warteschlangenarbeitern) hört die Warteschlange kontinuierlich zu, holt Aufgaben ab und führt sie aus.// Aufgaben zur Warteschlange hinzufügen (Beispiel mit Redis) private function addtasktoqueue ($ templateId, $ mobiles, $ content) { $ redis = new Redis (); $ redis-> connect ('127.0.0.1', 6379); $ redis-> lpush ('sms_queue', json_encode (['vorlampe_id' => $ templateId, 'mobiles' => $ mobiles, 'content' => $ content]); }
Nach dem Login kopieren -
Warteschlangenarbeiter: Warteschlangenarbeiter erhält Aufgaben aus der
sms_queue
-Warteschlange, führt SMS -Senden aus und verarbeitet Fehlerprotokolle.// Warteschlangenarbeiter (Beispiel) while (wahr) { $ task = $ redis-> rpop ('sms_queue'); if ($ task) { $ data = json_decode ($ task, true); $ result = $ this-> sendsms ($ data ['Vorlage_ID'], $ data ['Mobiles'], $ data ['Inhalt']); if ($ result! == true) { // log error_log ("SMS -Senden fehlgeschlagen:". $ Result); } } Schlaf (1); // Vermeiden Sie übermäßige CPU -Verwendung}
Nach dem Login kopieren SMS -Funktionsfunktion (
sendSms
) : Diese Funktion ruft die SMS -Dienstanbieter -API auf, um SMS -Nachrichten zu senden.
Durch die oben genannten Schritte wird die Front-End-Benutzererfahrung nicht beeinträchtigt, und das Back-End verarbeitet das Senden von Stapel-SMS effizient. Die Auswahl des richtigen Warteschlangensystems (Redis, Rabbitmq, BeaneStalkd usw.) ist entscheidend, was sicherstellt, dass die Aufgaben zuverlässig verarbeitet werden und verteilte Umgebungen unterstützt. Darüber hinaus ist auch ein vollständiger Fehlerbehebung und Protokollierungsmechanismus unerlässlich.
Das obige ist der detaillierte Inhalt vonWie löste ich den Hintergrund asynchroner Stapel -Senden von SMS -Nachrichten im Vordergrund aus, ohne die Benutzererfahrung zu beeinflussen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Auf CentOS -Systemen können Sie die Ausführungszeit von LuA -Skripten einschränken, indem Sie Redis -Konfigurationsdateien ändern oder Befehle mit Redis verwenden, um zu verhindern, dass bösartige Skripte zu viele Ressourcen konsumieren. Methode 1: Ändern Sie die Redis -Konfigurationsdatei und suchen Sie die Redis -Konfigurationsdatei: Die Redis -Konfigurationsdatei befindet sich normalerweise in /etc/redis/redis.conf. Konfigurationsdatei bearbeiten: Öffnen Sie die Konfigurationsdatei mit einem Texteditor (z. B. VI oder Nano): Sudovi/etc/redis/redis.conf Setzen Sie die LUA -Skriptausführungszeit.

In diesem Artikel wird erläutert, wie die Effizienz der Hadoop -Datenverarbeitung auf Debian -Systemen verbessert werden kann. Optimierungsstrategien decken Hardware -Upgrades, Parameteranpassungen des Betriebssystems, Änderungen der Hadoop -Konfiguration und die Verwendung effizienter Algorithmen und Tools ab. 1. Hardware -Ressourcenverstärkung stellt sicher, dass alle Knoten konsistente Hardwarekonfigurationen aufweisen, insbesondere die Aufmerksamkeit auf die Leistung von CPU-, Speicher- und Netzwerkgeräten. Die Auswahl von Hochleistungs-Hardwarekomponenten ist wichtig, um die Gesamtverarbeitungsgeschwindigkeit zu verbessern. 2. Betriebssystem -Tunes -Dateideskriptoren und Netzwerkverbindungen: Ändern Sie die Datei /etc/security/limits.conf, um die Obergrenze der Dateideskriptoren und Netzwerkverbindungen zu erhöhen, die gleichzeitig vom System geöffnet werden dürfen. JVM-Parameteranpassung: Einstellen in der Hadoop-env.sh-Datei einstellen

Das Erstellen eines Hadoop -verteilten Dateisystems (HDFS) auf einem CentOS -System erfordert mehrere Schritte. Dieser Artikel enthält einen kurzen Konfigurationshandbuch. 1. Bereiten Sie sich auf die Installation von JDK in der frühen Stufe vor: Installieren Sie JavadevelopmentKit (JDK) auf allen Knoten, und die Version muss mit Hadoop kompatibel sein. Das Installationspaket kann von der offiziellen Oracle -Website heruntergeladen werden. Konfiguration der Umgebungsvariablen: Bearbeiten /etc /Profildatei, setzen Sie Java- und Hadoop -Umgebungsvariablen, damit das System den Installationspfad von JDK und Hadoop ermittelt. 2. Sicherheitskonfiguration: SSH-Kennwortfreie Anmeldung zum Generieren von SSH-Schlüssel: Verwenden Sie den Befehl ssh-keygen auf jedem Knoten

Laden Sie das Quellcodepaket von der offiziellen Redis -Quelle herunter, um es zu kompilieren und zu installieren, um die neueste und stabile Version zu gewährleisten, und kann auf personalisierte Weise angepasst werden. Die spezifischen Schritte sind wie folgt: Aktualisieren Sie die Liste der Softwarepakets und erstellen

Aktivieren Sie Redis langsame Abfrageprotokolle im CentOS -System, um die Leistungsdiagnoseeffizienz zu verbessern. In den folgenden Schritten führen Sie die Konfiguration durch: Schritt 1: Suchen und bearbeiten Sie die Redis -Konfigurationsdatei zuerst und suchen Sie die Redis -Konfigurationsdatei, die sich normalerweise in /etc/redis/redis.conf befindet. Öffnen Sie die Konfigurationsdatei mit dem folgenden Befehl: Sudovi/etc/redis/redis.conf Schritt 2: Passen Sie die Langsame-Abfrage-Protokollparameter in der Konfigurationsdatei an, suchen Sie die folgenden Parameter: #Slow Query-Schwellenwert (MS) Slow-Log-Slow-Than10000 #Maximum der Einträge für langsame Query-Log-Logog-Logog-Len-Len-Len

Der Hadoop -Task -Ausführungsprozess enthält hauptsächlich die folgenden Schritte: Senden Sie den Job: Der Benutzer verwendet die von Hadoop auf dem Client -Computer bereitgestellten Befehlszeilen -Tools oder -APIs, um die Umgebung für die Ausführung von Aufgaben zu erstellen und die Aufgabe an Garn (Hadoop's Resource Manager) einzureichen. Ressourcenanwendung: Nachdem das Garn die Anforderung zur Einreichung von Aufgaben erhalten hat, wird die Ressourcen aus den Knoten im Cluster basierend auf den von der Aufgabe erforderlichen Ressourcen (wie Speicher, CPU usw.) beantragt. Aufgabe Start: Sobald die Ressourcenzuweisung abgeschlossen ist, sendet das Garn den Startbefehl der Aufgabe an den entsprechenden Knoten. Auf dem Knoten NodeMana

Beim Konfigurieren von Hadoop-Distributed Dateisystem (HDFS) auf CentOS müssen die folgenden Schlüsselkonfigurationsdateien geändert werden: Core-Site.xml: Fs.DefaultFs: Gibt die Standarddateisystemadresse von HDFs an, wie z. B. HDFS: // localhost: 9000. Hadoop.tmp.dir: Gibt das Speicherverzeichnis für Hadoop -temporäre Dateien an. Hadoop.proxyuser.root.hosts und Hadoop.proxyuser.ro

In diesem Artikel wird beschrieben, wie Sie mit Tigervnc Dateien auf Debian -Systemen teilen können. Sie müssen zuerst den Tigervnc -Server installieren und dann konfigurieren. 1. Installieren Sie den Tigervnc -Server und öffnen Sie das Terminal. Aktualisieren Sie die Softwarepaketliste: sudoaptupdate, um den Tigervnc Server zu installieren: sudoaptinstallTigervnc-standalone-servertigervnc-common 2. Konfigurieren Sie den Tigervnc-Server auf VNC-Serverkennwort: VNCPasswd VNC Server: VNCServer: 1-Lokalhostno-Kennwort
