suchen
HeimJavajavaLernprogrammZusammenfassung der Verwendung des Java-Thread-Pools

Bei einem kürzlich durchgeführten Projekt bin ich auf einige Situationen gestoßen, in denen ich häufig SQL-Abfragen verwenden, Dateien schreiben und Unteraufgaben aufteilen musste. Um den Programmdurchsatz zu verbessern, verwende ich einen Thread-Pool.

Erwägen Sie zu Beginn die Aufteilung der Benutzer entsprechend der Anzahl, da Oracle bei Datenbankabfragen eine Grenze von nicht mehr als 1.000 Abfragen für where in () hat. Erwägen Sie daher, alle 900 Benutzer in jeweils einen Slice aufzuteilen Slice ist eine Aufgabe und wird zur Verarbeitung an den Fix-Thread-Pool übergeben.

Aber jede Aufgabe hat zwei größere Unteraufgaben: das Abfragen von Gutscheinen und das Abfragen der Anzahl der abzugebenden Kommentare. Diese beiden Unteraufgaben erfordern eine große Anzahl von SQL-Abfragen, daher haben wir überlegt, diese beiden Unteraufgaben in Aufgaben zu kapseln zur Verarbeitung an den Thread-Pool übergeben. Da die Ausführung der Hauptaufgabe jedoch vom Ergebnis der Unteraufgabe abhängt, ist bei Verwendung desselben Thread-Pools nach der Übermittlung der Unteraufgabe die auszuführende Aufgabe in der Arbeitswarteschlange immer noch die Hauptaufgabe und die CPU Warten auf Future.get für die zuerst übermittelte Hauptaufgabe () kehrt zurück, die Unteraufgabe kann keine CPU-Ressourcen zur Ausführung erhalten und wartet in der Aufgabenwarteschlange, was dazu führt, dass das Programm auf den Tod wartet. Daher wurde der Thread-Pool von „Fix“ auf „Cache“ geändert, in der Hoffnung, dass die übermittelten Aufgaben CPU-Zeit erhalten und nicht die ganze Zeit in der Warteschlange warten müssen. Später verursachte dies auch Probleme, die im nächsten Artikel erläutert werden.

Wenn die Rechnungsdaten des Benutzers berechnet werden, muss das Vorlagencenter aufgerufen werden, um die E-Mail zu generieren, und die generierte E-Mail muss auf der Festplatte gespeichert werden. Dies sind zwei verschiedene IO-intensive Aufgaben, eine davon ist aktiviert Der Socket wartet, man wartet auf lokales IO. Wenn Sie weiterhin an den Cache-Thread-Pool senden, generiert der Thread-Pool für jede Aufgabe einen Thread, was viele Ressourcen verbraucht, und die CPU wechselt häufig den Thread, was den Durchsatz des Programms verringert. Erstellen Sie daher einen neuen Fix-Thread-Pool und senden Sie diese nachfolgenden Aufgaben zur Verarbeitung an den Fix-Thread-Pool. Der Thread-Pool verwendet eine feste Anzahl von Jobs zur Ausführung, wodurch das Programm unter verschiedenen Blockierungsbedingungen weiter ausgeführt werden kann und die Erstellung eines Jobs vermieden wird große Menge an Thread-Ressourcen.

Tatsächlich wurden im endgültigen Programm fünf Thread-Pools verwendet. Die Gründe für die hierarchische Verwendung sind wie folgt:

Um die Effizienz der Programmausführung zu verbessern, können Benutzer nach klassifiziert werden Zuerst die Sprache und dann in 900 Personen eingeteilt. Ein Teil wird fragmentiert, und jeder Teil der Aufgabe umfasst zwei Unteraufgaben, die häufig die Datenbank abfragen. Nach der Verarbeitung jedes Teils ist Netzwerk-E/A zum Erstellen von E-Mails und Festplatten-E/A zum Speichern von E-Mails erforderlich. Wenn derselbe Thread-Pool verwendet wird, warten nach der Übermittlung der von der übergeordneten Aufgabe erzeugten Unteraufgaben an den Fix-Thread-Pool verschiedene Arten von E/A-Vorgängen in der Aufgabenwarteschlange, da die Arbeitswarteschlange immer noch von der übergeordneten Aufgabe belegt ist den Systemdurchsatz verbessern. Nach der Übermittlung von Aufgaben auf niedrigerer Ebene an andere Thread-Pools haben die Aufgaben auf niedrigerer Ebene die Möglichkeit, sie sofort auszuführen und Netzwerk-E/A sowie Lese- und Schreibvorgänge auf der Festplatte durchzuführen, was die Betriebseffizienz 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
Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung?Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung?Mar 17, 2025 pm 05:46 PM

In dem Artikel werden Maven und Gradle für Java -Projektmanagement, Aufbau von Automatisierung und Abhängigkeitslösung erörtert, die ihre Ansätze und Optimierungsstrategien vergleichen.

Wie erstelle und verwende ich benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning und Abhängigkeitsmanagement?Wie erstelle und verwende ich benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning und Abhängigkeitsmanagement?Mar 17, 2025 pm 05:45 PM

In dem Artikel werden benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning- und Abhängigkeitsmanagement erstellt und verwendet, wobei Tools wie Maven und Gradle verwendet werden.

Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache?Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache?Mar 17, 2025 pm 05:44 PM

In dem Artikel wird in der Implementierung von mehrstufigem Caching in Java mithilfe von Koffein- und Guava-Cache zur Verbesserung der Anwendungsleistung erläutert. Es deckt die Einrichtungs-, Integrations- und Leistungsvorteile sowie die Bestrafung des Konfigurations- und Räumungsrichtlinienmanagements ab

Wie kann ich JPA (Java Persistence-API) für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden verwenden?Wie kann ich JPA (Java Persistence-API) für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden verwenden?Mar 17, 2025 pm 05:43 PM

In dem Artikel werden mit JPA für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden erläutert. Es deckt Setup, Entity -Mapping und Best Practices zur Optimierung der Leistung ab und hebt potenzielle Fallstricke hervor. [159 Charaktere]

Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle?Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle?Mar 17, 2025 pm 05:35 PM

Mit der Klassenbelastung von Java wird das Laden, Verknüpfen und Initialisieren von Klassen mithilfe eines hierarchischen Systems mit Bootstrap-, Erweiterungs- und Anwendungsklassenloadern umfasst. Das übergeordnete Delegationsmodell stellt sicher

See all articles

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor