ThreadPool - vorhandene thread liste überprüfen bzw. aufräumen

redbomber

Bekanntes Mitglied
Hi zusammen,
ich habe eine Frage wie ich folgende Punkte bei mir korrekt implementieren soll:

Ich habe einen ThreadPool, bei dem ich einen minCount und maxCount (minimale/maximale Anzahl Threads) angeben kann.

1. Initialiserung:
Wie soll der Pool initialisiert werden? Soll ich im Konstruktor direkt die minimale Anzahl an Thread initialisieren? Oder warte ich bis die Anfragen kommen.

2. Threads aufräumen:
Jeder Worker-Thread in meinem Thread-Pool kann ausgeliehen werden und wird dann als used markiert.
Mein Thread-Pool hat nun einen CleanerThread, welcher zyklisch die Liste aller vorhandenen Threads prüft.
Hier prüfe ich:
- Ist thread noch ok? falls nein dann lösche Thread
- Ist thread noch ausgeliehen und ist ein Timeout aufgetreten? falls ja dann lösche Thread
Danach habe ich meine Liste "aufgeräumt" und enthält nur noch funktionierende Worker-Threads.
Was mache ich jetzt? Soll ich wieder soviele Worker-Threads initialiieren bis die minimale Anzahl an Threads erricht ist?

hier mal meine Aufräum-Methode welche in einem separatem CleanerThread abläuft:
Java:
private Vector<WorkerThread>        workerThreads;

private synchronized void cleanupConnections() {
      if (cleanupThread.isClosing()) {
         return;
      }
      long lTimeOut = System.currentTimeMillis() - UNUSED_TIMEOUT;

      Enumeration<WorkerThread> availableThreads= workerThreads.elements();

      while ((availableThreads!= null) && (availableThreads.hasMoreElements())) {
         WorkerThread oneWorkerThread= (WorkerThread) availableThreads.nextElement();
// lösche alle threads bei denen es einen Fehler gab
         if ((oneWorkerThread.isError())) {
            workerThreads.remove(oneWorkerThread);
            continue;
         }
// lösche alle threads bei denen es einen Timout gab
         if ((workerThreads.inUse()) && (lTimeOut > workerThreads.getLastUse())) {
            workerThreads.remove(oneWorkerThread);
            continue;
         }
      }
// ab hier könnte die Liste der vorhanden WorkerThreads leer sein. Soll ich jetzt die minimale Anzahl an Threads initialisieren?
   }
 
Zuletzt bearbeitet:
S

SlaterB

Gast
wie soll dir dazu jemand was beantworten?
ob du die Threads schon vorher initialisierst hängt z.B. davon ab ob dir dazu später die Zeit fehlt, was in Java eigentlich kaum Sinn ergibt,

wenn schon, ist eher zu vermuten dass ein unnötig initialisierter Thread minimal das System belastet,
lasse das sein, erstelle sie nur wenn nötig

was eine "minimale Anzahl Threads" bei den ganzen zu bedeuten hat ist natürlich auch wieder fraglich,
wenn das schon ganz am Anfang in den Spezifikationen verdrahtet ist, sollten vielleicht wirklich Threads laufen,
oder eben "minimale Anzahl Threads" mit entfernen..

edit:
einen 'kaputten' Thread zu entfernen ist auch relativ fraglich,
ich weiß nicht wie offizielle ThreadPools das machen, aber in einem solchen Fall könnte der Pool auch komplett auf Error gehen,
höchstens noch andere Threads beenden, und der User soll dann mal was machen, z.B. neuen Pool anlegen
 
Zuletzt bearbeitet von einem Moderator:

redbomber

Bekanntes Mitglied
hey, vielen Dank euch erst einmal für die Antworten.
@SlaterB, du hast Recht. So ist das nicht zu beantworten und so habe ich es für mich selbst definiert was für mich die beste Art der Initialisierung ist:

1. Anzahl-Threads< minThreadCount: erstelle neuen Thread
2. Anzahl-Threads>= minThreadCount && Anzahl-Threads< maxThreadCount: gebe freien Thread zurück bzw. erstelle neuen wenn maxThreadCount noch nicht erreicht
3. Wenn alle Threads belegt und maxThreadCount erreicht, muss ich irgendwie warten (bin ich noch dran)

@turtle:
Danke! Da sehe ich auch wie ich vielleicht mein aktuelles Problem mit dem 3. Punkt bei der Initialisierung lösen kann. Ich denke ich muss die Aufgaben irgendwie in eine Queue einreihen...

@SlaterB:
Noch zu dem aufräumen der Threads:
Bei mir bedeutet ein error() bei meinem WorkerThread, dass z.B. eine Verbindung abgebrochen ist.
Daher denke ich dass ich bei mir diese Strategie verwenden kann. D.h. meine WorkerThreads die keine "Verbindung" mehr haben, beende ich einfach (die würden mir ja auch nichts mehr bringen).
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
R Threads Exceptions von Threads abfangen im ThreadPool Allgemeine Java-Themen 5
T Loadbalanced Threadpool Allgemeine Java-Themen 9
O Fehler in Listing aus Buch ? Thema: Threads und Threadpool Allgemeine Java-Themen 8
Neumi5694 Best Practice Vorhandene Programminstanz nutzen Allgemeine Java-Themen 3
M Poi-Excel: vorhandene Formatierung verwenden Allgemeine Java-Themen 2
U Communityfunktionen für vorhandene Webseite Allgemeine Java-Themen 2
P Copiler soll nicht vorhandene Methoden ignorieren Allgemeine Java-Themen 2
F Evtl. nicht vorhandene Methode aufrufen Allgemeine Java-Themen 3
G Daten in eine vorhandene Excel-Datei schreiben Allgemeine Java-Themen 3
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
smarterToby Wie stoppe ich diesen Thread Allgemeine Java-Themen 4
A Thread.sleep Problem Allgemeine Java-Themen 2
J Thread started nur einmal Allgemeine Java-Themen 19
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
OnDemand Logfile pro User / Thread Allgemeine Java-Themen 7
OnDemand Thread / Service abbrechen Allgemeine Java-Themen 3
Thallius Ist meine static Helper Class Thread save? Allgemeine Java-Themen 9
P Swing Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: npoints > xpoints.length || npoints > ypoints.length Allgemeine Java-Themen 5
B Thread.sleep() in EJB Container wie lösen? Allgemeine Java-Themen 11
S Ist das Neuzuweisen von Feldern atomic und damit Thread-Safe? Allgemeine Java-Themen 2
S Exception in thread "main" java.lang.NullPointerException at FamilienApp.main(FamilienApp.java:15) Allgemeine Java-Themen 1
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
E HILFE !! Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/io/FileUtils Allgemeine Java-Themen 4
Flynn Thread-Problem... Allgemeine Java-Themen 2
G Thread-Programmierung Allgemeine Java-Themen 5
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
G Beendet sich der Thread selbst?! Allgemeine Java-Themen 3
mrbig2017 Sleep wird ignoriert und der Thread wartet nicht Allgemeine Java-Themen 1
S Thread beenden Allgemeine Java-Themen 9
M Array aus Thread Objekten erstellen Allgemeine Java-Themen 2
Aruetiise Swing JOptionPane ohne denn Thread zu pausieren Allgemeine Java-Themen 1
M Nanosekunden-Pause innerhalb einen Thread-Loops Allgemeine Java-Themen 3
E Thread Exception Allgemeine Java-Themen 6
javaerd Binomialkoeffizient ausrechnen, Exception in thread "main" java.lang.StackOverflowError Allgemeine Java-Themen 6
T Merkwürdiges Thread-Verhalten Allgemeine Java-Themen 6
K Thread Problem Allgemeine Java-Themen 6
W Thread sleep 30 sekunden - wenn keine Antwort bis dahin neu senden Allgemeine Java-Themen 2
H Thread bleibt stehen bei jar in jar Allgemeine Java-Themen 1
J Threads HTTP Request (Thread) dauert lange - in Android Allgemeine Java-Themen 3
F CPU Last eines Thread ausfindig machen Allgemeine Java-Themen 0
V Compiler-Fehler Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: Index: 125, Size: 125 Allgemeine Java-Themen 11
Tausendsassa Threads Einen Thread sich selbst schließen lassen Allgemeine Java-Themen 17
P Threads BufferedImage, Thread Concurrency Allgemeine Java-Themen 1
M Klasse in separaten Thread ausführen.Wie genau? Allgemeine Java-Themen 2
llabusch Thread blockiert Dialog Allgemeine Java-Themen 1
J Thread wait() Allgemeine Java-Themen 2
V Thread.sleep und InterruptedException? Allgemeine Java-Themen 1
G Thread nicht von GC zerstört Allgemeine Java-Themen 6
J Wie erschaffe ich einen sicheren Datenaustausch zwischen Thread und Nicht-Threads Allgemeine Java-Themen 8
Sogomn Thread blocken bis Taste gedrückt Allgemeine Java-Themen 5
T Starten vom Thread Allgemeine Java-Themen 3
T Wait/Notify() bei Thread Allgemeine Java-Themen 6
J Exception in thread "main" java.lang.NoClassDefFoundError Allgemeine Java-Themen 4
M Exception in thread "AWT-EventQueue-0" Allgemeine Java-Themen 6
Q Thread wacht nicht auf Allgemeine Java-Themen 7
T Fragen zum Thread-Thema Allgemeine Java-Themen 4
T Threads Input/Output im Thread - Datei ohne Inhalt Allgemeine Java-Themen 1
T Fragen zum Thread-Thema Allgemeine Java-Themen 9
C Threads Variablen in einem Thread Aktualisieren Allgemeine Java-Themen 17
U Thread beenden Allgemeine Java-Themen 3
W Threads Mit Thread und Runtime externe Programme öffnen Allgemeine Java-Themen 0
N Thread interrupt Status debuggen Allgemeine Java-Themen 6
A Thread: Code paralell ausführen in mehreren Instanzen Allgemeine Java-Themen 1
E Threads linkedlist/multi-thread problem Allgemeine Java-Themen 3
B Erkennen, wann Prozess beendet ist, dann Thread beenden. Allgemeine Java-Themen 6
A Thread Fehler absichtlich provozieren Allgemeine Java-Themen 3
B Threads Java Thread kommunizieren Allgemeine Java-Themen 12
N Thread Sicherheit im komplexen Datenmodell Allgemeine Java-Themen 7
K Thread richtig benutzen Allgemeine Java-Themen 3
K Exception in thread "AWT-EventQueue-1" Allgemeine Java-Themen 2
vandread Problem bei kleiner Thread-Übung Allgemeine Java-Themen 2
G Thread erzeugt nicht plausible NullPointerException Allgemeine Java-Themen 7
H Netbeans Warning bei Thread.sleep in Schleife Allgemeine Java-Themen 4
P [Thread] Scheint nicht Sequenziell zu Arbeiten Allgemeine Java-Themen 9
A eine test thread.join() frage Allgemeine Java-Themen 2
tuttle64 Verständnisprobleme mit Thread Locks Allgemeine Java-Themen 4
G Threads Thread bei Datenabfrage Allgemeine Java-Themen 3
S Thread anhalten per Button ? Allgemeine Java-Themen 3
E Thread Programmierung Allgemeine Java-Themen 2
S Threads ServerSocket-Thread soll schlafen, bis er gebraucht wird Allgemeine Java-Themen 2
V Thread schneller stoppen Allgemeine Java-Themen 2
V anstatt thread.join() einfach while schleife? Allgemeine Java-Themen 8
B Mausbewegung im Thread erkennen (hoch/runter) Allgemeine Java-Themen 6
G Linux/C++/Pthreads auf JVM zugreifen, thread safe? Allgemeine Java-Themen 10
K Threads Probleme mit Thread Allgemeine Java-Themen 13
K Threads Thread überprüfen Allgemeine Java-Themen 3
Z Threads Thread für einen Client Allgemeine Java-Themen 9
M Thread JavaFish Allgemeine Java-Themen 10
G Thread.sleep Allgemeine Java-Themen 12
M Threads Viele Aufrufe aus Thread, komisches Verhalten Allgemeine Java-Themen 8
B Threads Main Thread warten auf abgebrochen Task warten lassen Allgemeine Java-Themen 25
K Timer Thread Allgemeine Java-Themen 8
M Methoden Static Methoden und Thread??? Allgemeine Java-Themen 4
N java.lang.IllegalMonitorStateException: object not locked by thread before notify() Allgemeine Java-Themen 2
C Mehothode in anderenm Thread aufrufen Allgemeine Java-Themen 10
R Thread läuft nicht?! Allgemeine Java-Themen 7
J Anderem Thread Variable mitgeben Allgemeine Java-Themen 2
C Argument an einen Thread übergeben Allgemeine Java-Themen 4
S java.util.ConcurrentModificationException - aber nur ein Thread Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben