Heim Backend-Entwicklung PHP-Tutorial Wie löste ich den Hintergrund asynchroner Stapel -Senden von SMS -Nachrichten im Vordergrund aus, ohne die Benutzererfahrung zu beeinflussen?

Wie löste ich den Hintergrund asynchroner Stapel -Senden von SMS -Nachrichten im Vordergrund aus, ohne die Benutzererfahrung zu beeinflussen?

Mar 31, 2025 pm 11:45 PM
redis red talk

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.

Wie löste ich den Hintergrund asynchroner Stapel -Senden von SMS -Nachrichten im Vordergrund aus, ohne die Benutzererfahrung zu beeinflussen?

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:

  1. 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
  2. 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
  3. 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
  4. 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
  5. 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!

Erklärung dieser Website
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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

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

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So konfigurieren Sie die Ausführungszeit der Lua -Skript in CentOS Redis So konfigurieren Sie die Ausführungszeit der Lua -Skript in CentOS Redis Apr 14, 2025 pm 02:12 PM

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.

Wie Debian die Hadoop -Datenverarbeitungsgeschwindigkeit verbessert Wie Debian die Hadoop -Datenverarbeitungsgeschwindigkeit verbessert Apr 13, 2025 am 11:54 AM

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

Welche Schritte sind erforderlich, um CentOs in HDFs zu konfigurieren Welche Schritte sind erforderlich, um CentOs in HDFs zu konfigurieren Apr 14, 2025 pm 06:42 PM

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

So installieren Sie Redis in CentOS7 So installieren Sie Redis in CentOS7 Apr 14, 2025 pm 08:21 PM

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

So konfigurieren Sie langsame Abfragebogin in CentOS Redis So konfigurieren Sie langsame Abfragebogin in CentOS Redis Apr 14, 2025 pm 04:54 PM

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

Was ist der Ausführungsprozess von Debian Hadoop? Was ist der Ausführungsprozess von Debian Hadoop? Apr 13, 2025 am 11:24 AM

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

Welche Dateien müssen Sie in HDFS -Konfigurations -CentOS ändern? Welche Dateien müssen Sie in HDFS -Konfigurations -CentOS ändern? Apr 14, 2025 pm 07:27 PM

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

Tigervnc Share -Dateimethode auf Debian Tigervnc Share -Dateimethode auf Debian Apr 13, 2025 am 11:45 AM

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

See all articles