Heim Java javaLernprogramm Zusammenfassung der Verwendung des Java-Thread-Pools

Zusammenfassung der Verwendung des Java-Thread-Pools

Nov 22, 2016 pm 12:52 PM
java

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.


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

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 vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

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)

Perfekte Zahl in Java Perfekte Zahl in Java Aug 30, 2024 pm 04:28 PM

Leitfaden zur perfekten Zahl in Java. Hier besprechen wir die Definition, Wie prüft man die perfekte Zahl in Java?, Beispiele mit Code-Implementierung.

Zufallszahlengenerator in Java Zufallszahlengenerator in Java Aug 30, 2024 pm 04:27 PM

Leitfaden zum Zufallszahlengenerator in Java. Hier besprechen wir Funktionen in Java anhand von Beispielen und zwei verschiedene Generatoren anhand ihrer Beispiele.

Weka in Java Weka in Java Aug 30, 2024 pm 04:28 PM

Leitfaden für Weka in Java. Hier besprechen wir die Einführung, die Verwendung von Weka Java, die Art der Plattform und die Vorteile anhand von Beispielen.

Smith-Nummer in Java Smith-Nummer in Java Aug 30, 2024 pm 04:28 PM

Leitfaden zur Smith-Zahl in Java. Hier besprechen wir die Definition: Wie überprüft man die Smith-Nummer in Java? Beispiel mit Code-Implementierung.

Fragen zum Java Spring-Interview Fragen zum Java Spring-Interview Aug 30, 2024 pm 04:29 PM

In diesem Artikel haben wir die am häufigsten gestellten Fragen zu Java Spring-Interviews mit ihren detaillierten Antworten zusammengestellt. Damit Sie das Interview knacken können.

Brechen oder aus Java 8 Stream foreach zurückkehren? Brechen oder aus Java 8 Stream foreach zurückkehren? Feb 07, 2025 pm 12:09 PM

Java 8 führt die Stream -API ein und bietet eine leistungsstarke und ausdrucksstarke Möglichkeit, Datensammlungen zu verarbeiten. Eine häufige Frage bei der Verwendung von Stream lautet jedoch: Wie kann man von einem Foreach -Betrieb brechen oder zurückkehren? Herkömmliche Schleifen ermöglichen eine frühzeitige Unterbrechung oder Rückkehr, aber die Stream's foreach -Methode unterstützt diese Methode nicht direkt. In diesem Artikel werden die Gründe erläutert und alternative Methoden zur Implementierung vorzeitiger Beendigung in Strahlverarbeitungssystemen erforscht. Weitere Lektüre: Java Stream API -Verbesserungen Stream foreach verstehen Die Foreach -Methode ist ein Terminalbetrieb, der einen Vorgang für jedes Element im Stream ausführt. Seine Designabsicht ist

Zeitstempel für Datum in Java Zeitstempel für Datum in Java Aug 30, 2024 pm 04:28 PM

Anleitung zum TimeStamp to Date in Java. Hier diskutieren wir auch die Einführung und wie man Zeitstempel in Java in ein Datum konvertiert, zusammen mit Beispielen.

Gestalten Sie die Zukunft: Java-Programmierung für absolute Anfänger Gestalten Sie die Zukunft: Java-Programmierung für absolute Anfänger Oct 13, 2024 pm 01:32 PM

Java ist eine beliebte Programmiersprache, die sowohl von Anfängern als auch von erfahrenen Entwicklern erlernt werden kann. Dieses Tutorial beginnt mit grundlegenden Konzepten und geht dann weiter zu fortgeschrittenen Themen. Nach der Installation des Java Development Kit können Sie das Programmieren üben, indem Sie ein einfaches „Hello, World!“-Programm erstellen. Nachdem Sie den Code verstanden haben, verwenden Sie die Eingabeaufforderung, um das Programm zu kompilieren und auszuführen. Auf der Konsole wird „Hello, World!“ ausgegeben. Mit dem Erlernen von Java beginnt Ihre Programmierreise, und wenn Sie Ihre Kenntnisse vertiefen, können Sie komplexere Anwendungen erstellen.

See all articles