Heim Backend-Entwicklung C#.Net-Tutorial C# implementiert eine asynchrone Nachrichtenwarteschlange

C# implementiert eine asynchrone Nachrichtenwarteschlange

Dec 27, 2016 pm 02:31 PM

Nachrichtenwarteschlange

Nachrichtenwarteschlange (englisch: Message queue) ist eine Methode zur Kommunikation zwischen Prozessen oder zur Kommunikation zwischen verschiedenen Threads desselben Prozesses a Eine Reihe von Eingaben, normalerweise vom Benutzer. Die Nachrichtenwarteschlange stellt ein asynchrones Kommunikationsprotokoll bereit. Jeder Datensatz in der Warteschlange enthält detaillierte Informationen, einschließlich des Zeitpunkts des Auftretens, des Typs des Eingabegeräts und spezifischer Eingabeparameter. Das heißt, der Absender und Empfänger der Nachricht sind nicht erforderlich um gleichzeitig mit der Nachrichtenwarteschlange zu interagieren. Die Nachricht bleibt in der Warteschlange, bis der Empfänger sie abruft.

Um es einfach auszudrücken: Die Warteschlange speichert die Befehle, die wir verarbeiten müssen, erhält die Verarbeitungsergebnisse jedoch nicht rechtzeitig

Implementierung

Tatsächlich werden Nachrichtenwarteschlangen häufig in verknüpften Listenstrukturen gespeichert. Prozesse mit der Berechtigung können Nachrichten aus der Nachrichtenwarteschlange schreiben oder lesen.

Derzeit gibt es viele Open-Source-Implementierungen von Nachrichtenwarteschlangen, darunter JBoss Messaging, JORAM, Apache ActiveMQ, Sun Open Message Queue, Apache Qpid und HTTPSQS.

Vorteile, Nachteile

Die Nachrichtenwarteschlange selbst ist asynchron, was es dem Empfänger ermöglicht, die Nachricht lange nach dem Senden der Nachricht abzurufen, was sich von den meisten Kommunikationsprotokollen unterscheidet. Beispielsweise ist das im WWW verwendete HTTP-Protokoll synchron, da der Client nach einer Anfrage auf die Antwort des Servers warten muss. Es gibt jedoch viele Situationen, in denen wir asynchrone Kommunikationsprotokolle benötigen. Beispielsweise benachrichtigt ein Prozess einen anderen Prozess, dass ein Ereignis aufgetreten ist, muss jedoch nicht auf eine Antwort warten. Die asynchrone Natur der Nachrichtenwarteschlange hat jedoch auch einen Nachteil: Der Empfänger muss die Nachrichtenwarteschlange abfragen, um die neueste Nachricht zu empfangen.

Im Vergleich zu Signalen können Nachrichtenwarteschlangen mehr Informationen übertragen. Im Vergleich zu Pipes stellen Nachrichtenwarteschlangen formatierte Daten bereit, was die Arbeitsbelastung des Entwicklers verringern kann. Für Nachrichtenwarteschlangen gelten jedoch weiterhin Größenbeschränkungen.

Warteschlangennachrichten lesen

Es gibt hauptsächlich zwei Arten (1) Push durch den Server; (2) Pull durch den Client

Pull: Hauptsächlich fragt der Client regelmäßig ab Nachrichtenverarbeitung erhalten;

Push: Abonnenten durch Ereignisabonnement aktiv zur Verarbeitung benachrichtigen

Einfache Speicherung wird durch eine speicherverknüpfte Liste erreicht; DB, wie Redis; kann auch in lokalen Dateien gespeichert werden.

So stellen Sie die Konsistenz der asynchronen Verarbeitung sicher

Obwohl der Hauptzweck der Warteschlange darin besteht, Nachrichten zu speichern, asynchronisiert sie auch Aufrufe und Umsetzungen. Wenn Sie jedoch eine Konsistenz bei der Verarbeitung von Nachrichten erreichen möchten, besteht eine gute Möglichkeit darin, die Reihenfolge der Geschäftsverarbeitung zu unterscheiden, z. B. den Betrieb der Master-Slave-Datenbank. Der Master ist für das Schreiben und der Slave für das Lesen verantwortlich Wir haben keine Chance, die gewünschten Ergebnisse durch das Lesen der Datenbank sofort nach dem Schreiben zu erhalten. Gleichzeitig müssen wir Zwischenzustände verwenden, um die Ergebnisse des Anrufs gleichzeitig zu verarbeiten. Die „Ausnahmemeldung“ bleibt bis zum nächsten Vorgang bestehen.

Der obige Code

Nachrichtenunterstützungs-Kernwarteschlange einrichten

Ereignisverarbeitung
{    public delegate void MessageQueueEventNotifyHandler(Message.BaseMessage message);
 
    public class MessageQueue:Queue<BaseMessage>
    {
        public static MessageQueue GlobalQueue = new MessageQueue();
 
        private Timer timer = new Timer();
        public MessageQueue() {
            this.timer.Interval = 5000;
            this.timer.Elapsed += Notify;
            this.timer.Enabled = true;
        }
        private void Notify(object sender, ElapsedEventArgs e) {
            lock (this) {
                if (this.Count > 0) {
                    //this.messageNotifyEvent.GetInvocationList()[0].DynamicInvoke(this.Dequeue());
                    var message = this.Dequeue();
                    this.messageNotifyEvent(message);
                }
            }
        }
 
        private MessageQueueEventNotifyHandler messageNotifyEvent;
        public event MessageQueueEventNotifyHandler MessageNotifyEvent {
            add {
                this.messageNotifyEvent += value;
            }
 
            remove {
                if (this.messageNotifyEvent != null) {
                    this.messageNotifyEvent -= value;
                }
            }
        }
    }
}
Nach dem Login kopieren

public const string OrderCodePrefix = "P";        public void Submit(Message.BaseMessage message)
        {
            Order order = message.Body as Order;
 
            if (order.OrderCode.StartsWith(OrderCodePrefix))
            {
                System.Console.WriteLine("这个是个正确的以({0})开头的订单:{1}", OrderCodePrefix,order.OrderCode);
            }
            else {
                System.Console.WriteLine("这个是个错误的订单,没有以({0})开头:{1}",OrderCodePrefix,order.OrderCode);
            }
        }
Nach dem Login kopieren
Kann je nach Unternehmen personalisiert werden

Nachrichten über Proxy an die Warteschlange anhängen

Der Kunde ruft an
public class OrderServiceProxy:IOrderService    {
        public void Submit(Message.BaseMessage message)
        {
            MessageQueue.MessageQueue.GlobalQueue.Enqueue(message);
        }
    }
Nach dem Login kopieren

Dies erfüllt die Anforderungen der Ereignisbindung und des Auslösens einer personalisierten Verarbeitung und erreicht gleichzeitig die Asynchronität von Nachrichten. Zum Zwecke der Transformation hoffe ich, es detaillierter zu erweitern und in späteren Projekten zu verwenden.
OrderService orderService = new OrderService();            MessageQueue.MessageQueue.GlobalQueue.MessageNotifyEvent += orderService.Submit;
 
            var orders = new List<Order>() {
                new Order(){OrderCode="P001"},
                new Order(){OrderCode="P002"},
                new Order(){OrderCode="B003"}
            };
 
            OrderServiceProxy proxy = new OrderServiceProxy();
            orders.ForEach(order => proxy.Submit(new Message.BaseMessage() { Body=order}));
 
            Console.ReadLine();
Nach dem Login kopieren

Das Obige ist der Inhalt von C# zur Implementierung einer asynchronen Nachrichtenwarteschlange. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!


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)

Active Directory mit C# Active Directory mit C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Active Directory mit C#. Hier besprechen wir die Einführung und die Funktionsweise von Active Directory in C# sowie die Syntax und das Beispiel.

C#-Serialisierung C#-Serialisierung Sep 03, 2024 pm 03:30 PM

Leitfaden zur C#-Serialisierung. Hier besprechen wir die Einführung, die Schritte des C#-Serialisierungsobjekts, die Funktionsweise bzw. das Beispiel.

Zufallszahlengenerator in C# Zufallszahlengenerator in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zum Zufallszahlengenerator in C#. Hier besprechen wir die Funktionsweise des Zufallszahlengenerators, das Konzept von Pseudozufallszahlen und sicheren Zahlen.

C#-Datenrasteransicht C#-Datenrasteransicht Sep 03, 2024 pm 03:32 PM

Leitfaden zur C#-Datenrasteransicht. Hier diskutieren wir die Beispiele, wie eine Datenrasteransicht aus der SQL-Datenbank oder einer Excel-Datei geladen und exportiert werden kann.

Muster in C# Muster in C# Sep 03, 2024 pm 03:33 PM

Leitfaden zu Mustern in C#. Hier besprechen wir die Einführung und die drei wichtigsten Arten von Mustern in C# zusammen mit ihren Beispielen und der Code-Implementierung.

Primzahlen in C# Primzahlen in C# Sep 03, 2024 pm 03:35 PM

Leitfaden zu Primzahlen in C#. Hier besprechen wir die Einführung und Beispiele von Primzahlen in C# sowie die Codeimplementierung.

Fakultät in C# Fakultät in C# Sep 03, 2024 pm 03:34 PM

Leitfaden zur Fakultät in C#. Hier diskutieren wir die Einführung in die Fakultät in C# zusammen mit verschiedenen Beispielen und Code-Implementierungen.

Der Unterschied zwischen Multithreading und asynchronem C# Der Unterschied zwischen Multithreading und asynchronem C# Apr 03, 2025 pm 02:57 PM

Der Unterschied zwischen Multithreading und Asynchron besteht darin, dass Multithreading gleichzeitig mehrere Threads ausführt, während asynchron Operationen ausführt, ohne den aktuellen Thread zu blockieren. Multithreading wird für rechenintensive Aufgaben verwendet, während asynchron für die Benutzerinteraktion verwendet wird. Der Vorteil des Multi-Threading besteht darin, die Rechenleistung zu verbessern, während der Vorteil von Asynchron nicht darin besteht, UI-Threads zu blockieren. Die Auswahl von Multithreading oder Asynchron ist von der Art der Aufgabe abhängt: Berechnungsintensive Aufgaben verwenden Multithreading, Aufgaben, die mit externen Ressourcen interagieren und die UI-Reaktionsfähigkeit asynchron verwenden müssen.

See all articles