Reaktive Programmierung in Java mit Projektreaktor und Spring WebFlux
Jul 29, 2025 am 12:04 AMResponsive Programming implementiert eine hohe Parallelit?t, nicht blockierende Dienste mit geringer Latenz in Java durch Project Reactor und Spring WebFlux. 1. Project Reactor bietet zwei Kerntypen: Mono und Fluss, unterstützt die deklarative Verarbeitung asynchroner Datenflüsse sowie Konvertiten, Filter und andere Operationen über Operatorketten; 2. Spring WebFlux basiert auf Reaktor und unterstützt zwei Programmiermodelle für Annotations- und Funktionsmodelle. Es l?uft auf nicht blockierenden Servern wie Netty und kann gro?e Mengen gleichzeitiger Verbindungen effizient verarbeiten. 3. Die Verwendung von WebFlux-Reaktor kann die Parallelit?tsfunktionen und die Ressourcenauslastung in I/O-intensiven Szenarien verbessern, natürliche Streaming-Kommunikation wie SSE und Websocket unterstützt und sich nahtlos in reaktionsschnelle Datenbanken wie R2DBC und MongoDB integriert. V. 5. Obwohl die Lernkurve steil und für CPU-intensive Aufgaben nicht geeignet ist, kann diese Kombination den Systemdurchsatz und die Widerstandsf?higkeit in Microservices, Gateways und Echtzeitsystemen erheblich verbessern und ist es wert, in geeigneten Szenarien eingesetzt zu werden.
Die reaktive Programmierung ist in den letzten Jahren in Java immer wichtiger geworden, insbesondere in modernen Webanwendungen mit hoher Parallelit?t und geringer Latenz. Mit Project Reactor und Spring WebFlux k?nnen Java-Entwickler problemlos nicht blockierende, ereignisgesteuerte Dienste erstellen. Schauen wir uns an, wie sie zusammenarbeiten und warum Sie sie verwenden sollten.

Was ist reaktionsschnelle Programmierung?
Responsive Programmierung ist ein Programmierparadigma für den Datenfluss und die ?nderung der Ausbreitung . Sie k?nnen asynchrone Datenstr?me deklarativ verarbeiten, wie z. B. HTTP -Anforderungen, Datenbankantworten, Nachrichtenwarteschlangen usw.
Bei der traditionellen Blockierungsprogrammierung nimmt jede Anfrage einen Thread ein und wartet auf die Abschluss des E/A -Vorgangs. Bei reaktionsschnellem Programmieren werden Threads nicht blockiert, sondern nur dann verarbeitet, wenn Daten über den Mechanismus "Rückruf" oder "Ver?ffentlichungsunterschrift" verfügbar sind.

Projektreaktor: Die Kernbibliothek für reaktionsschnelle Programme
Project Reactor ist eine grundlegende JVM -Bibliothek, die vom Spring -Team für Responsive Systems erstellt wurde. Es handelt sich um eine Implementierung von Reaktor 3 und ist vollst?ndig mit der Reaktivstr?mespezifikation kompatibel.
Es bietet zwei Kerntypen:

-
Mono<t></t>
: repr?sentiert eine asynchrone Sequenz von 0 oder 1 Element (z. B. Ergebnisse der einzelnen Benutzerabfrage) -
Flux<t></t>
: repr?sentiert einen asynchronen Datenstrom von 0 bis N -Elementen (z. B. alle Benutzer holen)
// Beispiel: Erstellen Sie einen Fluss Flux <string> names = flux.just ("alice", "bob", "charlie"); // Erstellen Sie ein Mono Mono <string> Single = mono.just ("Hallo");
Sie k?nnen diese Streams wie map
, filter
, flatMap
, delayElements
usw. anketten.:
Namen .Map (String :: Touppercase) .Delayelemente (Dauer.Ofmillis (500)) .Subscribe (System.out :: println);
Hinweis: Der obige Code ist nicht blockiert und wird nicht sofort ausgeführt, sondern das Verhalten des Datenflusss "deklarieren" und wird erst ausgel?st, wenn ein "Abonnenten" erscheint.
Spring WebFlux: Responsive Web Framework
Spring WebFlux ist ein reaktionsschnelles Web -Framework, das von Spring 5 eingeführt wird. Es kann herk?mmliche Spring -MVC ersetzen und unterstützt zwei Programmiermodelle:
Annotierter Controller (?hnlich wie bei Spring MVC):
@Restcontroller ?ffentliche Klasse UserController { @Getmapping ("/user") public flux <user> getAllusers () { return userService.findall (); // Flux <Bener> zurückgeben } @Getmapping ("/user/{id}") public mono <Bene> getUserById (@PathVariable String id) { return userService.findbyId (id); // mono <user> zurückgeben } }
Funktionales Routing -Modell (leicht, funktional):
@Bohne ?ffentliche Routerfunktion <ServerResponse> Route (UserHandler -Handler) { Return Route (get ("/user"), Handler :: GetAllusers) .Androute (get ("/user/{id}"), Handler :: GetUserById); }
WebFlux unterstützt nicht blockierende Server wie Netty und Undertow, Netty wird empfohlen (der Standard ist in Spring Boot eingebettet, um Reaktor Netty zu verwenden).
Warum WebFlux -Reaktor verwenden?
H?here Parallelit?tsf?higkeit
Der traditionelle Tomcat nimmt einen Thread pro Anfrage ein und der Thread -Pool ist begrenzt. WebFlux verwendet eine kleine Anzahl von Ereignisschleifen -Threads (Ereignisschleifen), mit denen Tausende von gleichzeitigen Verbindungen verarbeitet werden k?nnen.Bessere Ressourcenauslastung
Nicht blockierende I/A reduziert das Warten von Faden, die CPU und die Speicherverwendung effizienter.Natürliche Unterstützung für Streaming -Daten
Solche Szenarien wie SSE (Server-Sent-Ereignisse), Websocket, Dateifluss, Echtzeit-Push usw. sind sehr geeignet.Nahtlose Integration in Frühlings?ko
Unterstützt reaktionsschnelle MongoDB, PostgreSQL (über R2DBC), Redis (Salat), Kafka usw.
Empfehlungen und Vorsichtsma?nahmen für den Gebrauch
Obwohl die Vorteile der reaktionsschnellen Programmierung offensichtlich sind, handelt es sich nicht um eine Silberkugel. Hier sind ein paar wichtige Punkte:
- ? Geeignet für I/O-intensive Szenarien : Aufrufen externer APIs, Datenbankzugriff und Nachrichtenverarbeitung.
- Es ist nicht für CPU-intensive Aufgaben geeignet : Reaktionsf?higkeit verbessert die Rechenleistung nicht, kann jedoch die Komplexit?t erh?hen.
- ??Don Mix of Mix Blocking Code : Aufrufen von
Thread.sleep()
oder Blockierung des Datenbankzugriffs imMono/Flux
zerst?rt den reaktionsschnellen Vorteil. - ? Vermeiden Sie das Schreiben von Gesch?ftslogik in Abonnement : Versuchen Sie, die Verarbeitung der Bedienerkette zu verwenden, um den funktionalen Stil aufrechtzuerhalten.
- ? Die Lernkurve ist steiler : Die Konzepte von Backdruck, Scheduler, hei?em und kaltem Fluss erfordern Zeit, um zu meistern.
Praktisches Beispiel: Aufrufen von externer API
Angenommen, wir m?chten Benutzerinformationen aus einem externen Dienst erhalten und die Konvertierung durchführen:
@Service Public Class Userservice { private endgültige webclient webclient = webclient.create ("https://api.example.com"); public mono <user> fetchuser (String -ID) { return webclient.get () .uri ("/user/{id}", id) .abrufen() .bodytomono (externaluser.class) . .Timeout (duration.ofseconds (3)) // Timeout Control.OnerRorreturn (user.Empty ()); // Fehlergarantie} }
Der gesamte Prozess ist nicht blockiert, und mehrere Anfragen k?nnen parallel bearbeitet werden, ohne zus?tzliche Threads zu konsumieren.
Zusammenfassen
- Project Reactor bietet grundlegende Operationen für reaktionsschnelle Streams (
Mono
/Flux
) - Spring WebFlux basiert auf Reaktor zur Implementierung von Responsive Web Services
- Kombination der beiden, geeignet für hohe Parallelit?t, I/O-intensive Anwendungen
- Bei der Verwendung müssen Sie vermeiden, Operationen zu blockieren und den Mechanismus zur Rückdruck- und Planungsmechanismus zu verstehen
Responsive Programmierung ist nicht überall notwendig, aber im richtigen Szenario kann es den Durchsatz und die Belastbarkeit des Systems erheblich verbessern. Wenn Sie ein Microservice-, Gateway-, Echtzeit-Schnittstellen- oder Stream-Verarbeitungssystem erstellen, verdient WebFlux-Reaktor ernsthafte überlegungen.
Grunds?tzlich ist alles, nicht kompliziert, aber es ist leicht, Details zu ignorieren.
Das obige ist der detaillierte Inhalt vonReaktive Programmierung in Java mit Projektreaktor und Spring WebFlux. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

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

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

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





Maven ist ein Standardwerkzeug für Java -Projektmanagement und -aufbau. Die Antwort liegt in der Tatsache, dass Pom.xml verwendet wird, um Projektstruktur, Abh?ngigkeitsmanagement, Konstruktionslebenszyklusautomation und Plug-in-Erweiterungen zu standardisieren. 1. Verwenden Sie POM.xml, um Gruppen, Artefaktid, Version und Abh?ngigkeiten zu definieren; 2. Master -Kernbefehle wie MVNClean, Compile, Test, Paket, Installation und Bereitstellen; Fn. V. 5.

Setupamaven/GradleProjectWithjax-rsdependencies-?hnlich Jersey; 2. CreatearestresourcEUntationSuchas@pathand@Get; 3.ConfiguretheApplicationviaApplicationSubclitsorweb.xml;

Um Hash -Werte mit Java zu generieren, kann es über die MessagedIGest -Klasse implementiert werden. 1. Holen Sie sich eine Instanz des angegebenen Algorithmus wie MD5 oder SHA-256; 2. Rufen Sie die Methode .update () auf, um die zu verschlüsselnden Daten zu übergeben. 3. Nennen Sie die Methode .Digest (), um ein Hash -Byte -Array zu erhalten. 4. Umwandeln Sie das Byte -Array in eine hexadezimale Zeichenfolge zum Lesen; Lesen Sie für Eingaben wie gro?e Dateien in Stücken und rufen Sie .update () mehrmals auf. Es wird empfohlen, SHA-256 anstelle von MD5 oder SHA-1 zu verwenden, um die Sicherheit zu gew?hrleisten.

Verstehen Sie die Kernkomponenten von Blockchain, einschlie?lich Bl?cken, Hashs, Kettenstrukturen, Konsensmechanismen und Unver?nderlichkeit; 2. Erstellen Sie eine Blockklasse, die Daten, Zeitstempel, frühere Hash und Nonce enth?lt, und implementieren Sie die SHA-256-Hash-Berechnung und den Nachweis des Arbeitsabbaus; 3.. Erstellen Sie eine Blockchain -Klasse, um Blocklisten zu verwalten, den Genesis -Block initialisieren, neue Bl?cke hinzufügen und die Integrit?t der Kette überprüfen. V. 5. Optionale Verbesserungsfunktionen umfassen Transaktionsunterstützung, P2P -Netzwerk, digitale Signatur, Restapi und Datenpersistenz; 6. Sie k?nnen Java-Blockchain-Bibliotheken wie Hyperledgerfabric, Web3J oder Corda zur Er?ffnung auf Produktionsebene verwenden

Ja, ein gemeinsames CSS-Dropdown-Menü kann mit reinem HTML und CSS ohne JavaScript implementiert werden. 1. Verwenden Sie verschachtelte UL und Li, um eine Menüstruktur zu erstellen. 2. Verwenden Sie die: Hover Pseudo-Klasse, um die Anzeige und das Verstecken von Pulldown-Inhalten zu steuern. 3.. Setzen Sie Position: Relativ für Eltern -Li, und das Untermenü wird unter Verwendung von Position positioniert: absolut; 4. Das untergeordnete Standards ist angezeigt: Keine, die angezeigt wird: Block, wenn sie schwebend sind; 5. Multi-Level-Pulldown kann durch Verschachtelung, kombiniert mit dem übergang und Fade-In-Animationen erzielt und an mobile Terminals mit Medienabfragen angepasst werden. Die gesamte L?sung ist einfach und erfordert keine JavaScript -Unterstützung, was für gro?e geeignet ist

@Property Decorator wird verwendet, um Methoden in Eigenschaften umzuwandeln, um die Les-, Einstellungs- und L?schsteuerung von Eigenschaften zu implementieren. 1. Grundnutzung: Definieren Sie nur schreibgeschützte Attribute über @Property, wie z. B. Bereich berechnet auf dem Radius und direkt zugegriffen; 2. Erweiterte Verwendung: Verwenden Sie @name.setter und @name.deleter, um die überprüfung der Attributzuweisung und L?schvorg?nge zu implementieren; 3. Praktische Anwendung: Führen Sie die Datenüberprüfung in Setzen durch, z. B. BankAccount, um sicherzustellen, dass der Restbetrag nicht negativ ist. 4. Benennungsspezifikation: Die internen Variablen sind vorangestellt, Eigenschaftennamen sind mit den Attributen überein, und eine einheitliche Zugriffskontrolle wird zur Verbesserung der Codesicherheit und -wartbarkeit verwendet.

Verwenden Sie zun?chst JavaScript, um die Einstellungen für Benutzersysteme und lokal gespeicherte Themeneinstellungen zu erhalten und das Seitenthema zu initialisieren. 1. Die HTML -Struktur enth?lt eine Schaltfl?che zum Ausl?sen von Themenwechsel. 2. CSS verwendet: root, um helle Themenvariablen zu definieren, .Dark-Mode-Klasse definiert dunkle Themenvariablen und wendet diese Variablen über var () an. 3.. JavaScript erkennt bevorzuge-farbige Scheme und liest LocalStorage, um das ursprüngliche Thema zu bestimmen. 4. Schalten Sie die Dark-Mode-Klasse im HTML-Element beim Klicken auf die Schaltfl?che und speichern Sie den aktuellen Status vor LocalStorage. 5. Alle Farb?nderungen werden mit einer übergangsanimation von 0,3 Sekunden begleitet, um den Benutzer zu verbessern

Vollbildlayout kann mit Flexbox oder Raster erreicht werden. Der Kern besteht darin, die minimale H?he der Seite zur H?he der Ansichtsfenster (min-H?he: 100VH) zu erstellen. 2. Verwenden Sie Flex: 1 oder Grid-Template-Reihen: Auto1Frauto, damit der Inhaltsbereich den verbleibenden Raum belegt; 3.. Set Box-Gr??en: Border-Box, um sicherzustellen, dass der Rand den Container nicht überschreitet. 4. Optimieren Sie die mobile Erfahrung mit reaktionsschnellem Medienabfrage; Diese L?sung ist mit einer guten Struktur kompatibel und für Anmeldeseiten, Dashboards und andere Szenarien geeignet.
