Frage zu Thread-Architektur

Status
Nicht offen für weitere Antworten.

JBubble

Mitglied
Hallo,

ich habe die Aufgabe, einen sog. Jobserver zu erstellen, welcher eine beliebige Anzahl von beliebigen Aufgaben bekommt und jede Aufgabe in einem eigenen Thread abarbeiten muss (Thread-per-request Architektur). Dies soll später mit einer ThreadPool-Architektur verglichen werden, doch zunächst zur per-request-Variante:

Die Jobs sind erstmal alle identisch und simulieren eine CPU-Belastung, indem jeder Job nichts anderes tut als eine Variable von 0 bis eine Milliarde hochzählt.

Um eine Gleichzeitigkeit zu simulieren, verfügt der Jobserver über folgende Methode performTask:

Code:
public void performTask(final IJob[] myJobs)

IJob ist ein Interface, welches von jedem Job implementiert wird und unter anderem eine Methode performTask enthält, welche die Aufgabe ausführt, hier also das Hochzählen. Um nun jeden Job in einem eigenen Thread zu starten, hab ich die Implementierung der Methode performTask auf dem Jobserver folgendermaßen gewählt:

Code:
public void performTask(final IJob[] myJobs) {
		for(int i=0; i<myJobs.length; i++) {
			// setze Zeit, wann der Job vom Server 'angenommen' wurde
			myJobs[i].setServerStart(System.currentTimeMillis());
			final IJob aktJob = myJobs[i];
			new Thread(new Runnable() {
				public void run() {
					aktJob.performTask();
				}
			}).start();
		}
	}

Die Jobs werden in einer anderen Klasse erzeugt und dann dem Server als Array übergeben. Ich halte u.a. folgende Zeitpunkte fest: Erstellung der Objekte, Annahme am Server (s. Kommentar im Code), Beginn der Ausführung, Ende der Ausführung.

Nun wundert mich das Ergebnis ein wenig, daher würde ich hier mal gern nachfragen ob das tatsächlich so sein kann oder ob ich irgendwo einen Denkfehler hab:

Läuft nur ein Job, so braucht dieser ca. 1,6s.
Fünf Jobs benötigen bereits durchschnittlich 7,9s. Die Zeit von der Erstellung der Objekte bis zur 'Annahme' auf dem Server (also quasi bis zur Erzeugung der Threads) ist noch 0s.
Zehn Jobs brauchen durchschnittlich etwa 15s (!), hier vergeht auch bei den letzten Jobs eine gewisse Zeit von der Erstellung bis zur Erzeugung der Threads (beim letzten Job ca. 0,3s).

Ich finde es etwas verwunderlich dass die Zeiten so schnell in die Höhe gehen. Ist das normal oder hab ich irgendwo einen Denkfehler oder Programmierfehler? Ferner würde ich gern alle Threads zum exakt gleichen Zeitpunkt starten, wie ließe sich so etwas realisieren? Denn wenn - wie im letzten Fall - der letzte Thread gestartet wird (so ergeben Auswertungen), läuft der Erste bereits seit 0,5s. Lässt sich hier eine absolute Gleichzeitigkeit überhaupt erreichen? Gibts evtl. ne bessere Möglichkeit als die Array-Variante, die ich oben gewählt hab?

Naja, ich danke schonmal jedem der sich das hier anschaut und ein paar Anmerkungen dazu schreibt.

Viele Grüsse,
JBubble
 
G

Guest

Gast
Du könntest jeden Thread über einen Timer starten lassen bzw. zu
einem bestimmten Zeitpunkt.
In der run()-Methode machst Du zuerst Thread.sleep(time2start - System.currentTimeMillis())
Dies sollte dazu führen, dass alle Threads ungefähr zum gleichen Zeitpunkt starten.
 
G

Guest

Gast
1 Thread = ca. 1,6s
10 Threads = ca. 15s oder sagen wir mal 16s
wobei alle Threads exakt das gleiche tun und auch gleiche Priorität haben.

1,6s * 10 = 16s

Die Threads teilen sich ja die CPU-Zeit. Wenn die Ausführungszeit gleicher Threads mit
gleicher Priorität schön gleichmäßig verteilt ist, dann ist ja alles in Ordnung ;)
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
A eine test thread.join() frage Allgemeine Java-Themen 2
N Frage zu Thread Allgemeine Java-Themen 12
O Thread Generelle Frage Allgemeine Java-Themen 2
D Timer oder Thread, das ist hier die Frage Allgemeine Java-Themen 3
S Thread Frage Allgemeine Java-Themen 2
T Frage zu Thread.sleep() Allgemeine Java-Themen 2
MiMa Grundsätzliche Frage zur Verwendung von Java Versionen?? Allgemeine Java-Themen 3
KonradN Mal eine Frage zu Binary Serialization Allgemeine Java-Themen 15
8u3631984 Frage zu Java Streams min / max Allgemeine Java-Themen 17
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Frage regex greater than less than Allgemeine Java-Themen 7
berserkerdq2 Frage zu IntelliJ und JavaFX Allgemeine Java-Themen 1
W Timer Konzept-Frage Allgemeine Java-Themen 16
T Eine Frage des Designs Allgemeine Java-Themen 2
C Frage zu eigenem TableCellRenderer Allgemeine Java-Themen 11
C Programmvorstellung & Frage zum Thema Geschäftsform Allgemeine Java-Themen 51
J Frage zu System.getproperties. Allgemeine Java-Themen 60
molat100 wie kann man die Frage beantworten Allgemeine Java-Themen 1
pkm Frage zur Präzision von Calendar.WEEK_OF_YEAR Allgemeine Java-Themen 12
J Eine Frage zu den Threads und Task Allgemeine Java-Themen 1
pkm Frage nach eventuellem syntaktischen Zucker bei der Konkatenation von ArrayLists Allgemeine Java-Themen 4
M Frage-Antwortspiel wie Wer wird Millionär Allgemeine Java-Themen 1
F Frage zu System.in Allgemeine Java-Themen 3
marcooooo Frage zum Beispiel im Anhang Allgemeine Java-Themen 16
T Meine Frage lautet wie ich 2 CSV Dateien miteinander in Java verbinde und Spalten die zueinander gehören durch den gleichen Key zusammen ausgebe? Allgemeine Java-Themen 5
S Noch eine Design-Frage zu Setter Allgemeine Java-Themen 6
B For-Loop Frage Allgemeine Java-Themen 21
L Java frage Allgemeine Java-Themen 3
bueseb84 Frage zu Mock und UpperBound Allgemeine Java-Themen 2
M Frage zum Konstruktor Allgemeine Java-Themen 2
W Best Practice Frage zur Umsetzung MVC Allgemeine Java-Themen 9
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
B Frage zu Unit-Tests Allgemeine Java-Themen 6
T Allgemeine Frage: GUI für 3D-Visualisierung Allgemeine Java-Themen 5
R Allgemeine Frage zu RMI bei MVC Allgemeine Java-Themen 2
O Frage zum Runtimeverhalten von Java ... Allgemeine Java-Themen 2
H Rundreise frage (Algorithmus) Allgemeine Java-Themen 18
B Generelle Frage bei einer Webanwendung / Reduzierung von DB Abfragen Allgemeine Java-Themen 1
D Frage zu Vererbung Allgemeine Java-Themen 5
J Frage zu regulärem Ausdruck Allgemeine Java-Themen 2
M Allgemeine Frage: Wie lernt man Java / Programmieren von Grund auf? Allgemeine Java-Themen 7
rentasad Design-Frage - Interfaces, Klassen, statische Methoden Allgemeine Java-Themen 3
S Frage zur JLS Allgemeine Java-Themen 0
J Verständnis Frage zur Instanz, Objekte, Instanzierung, Referenz Allgemeine Java-Themen 14
A Methoden Allgemeine Java Frage Allgemeine Java-Themen 3
E String Frage Allgemeine Java-Themen 9
I bin neu bei GitHub, Frage zur Sicherheit Allgemeine Java-Themen 14
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
C KeyListener Frage Allgemeine Java-Themen 3
T Frage zu UML in Java programmieren Allgemeine Java-Themen 1
R Konstanten initialisieren - FRAGE Allgemeine Java-Themen 3
MTJ004 FTP Frage zu FTP Speicherung Java-Android-FTP Allgemeine Java-Themen 5
J Frage zum Entwurf / json-Datenmodell Allgemeine Java-Themen 8
A Frage zu meinem Code Allgemeine Java-Themen 2
RalleYTN Classpath Nur ne kleine Frage zur MANIFEST.MF Allgemeine Java-Themen 4
T Frage zu Access Modifiers Allgemeine Java-Themen 6
W Input/Output Frage zu pdfbox und FileUtils Allgemeine Java-Themen 2
O Frage zur Implementierungsweise Allgemeine Java-Themen 4
B Frage zu Bitshift Allgemeine Java-Themen 3
J Java Zufallsgenerator (6 aus 49) Frage Allgemeine Java-Themen 7
L Frage zu RIA und GWT Allgemeine Java-Themen 0
P Concurrency Frage Allgemeine Java-Themen 8
M Frage zu Enumerations Allgemeine Java-Themen 2
F Unlimited Strength Policy. Frage Verbreitung der Anwendung Allgemeine Java-Themen 1
F Frage zur Library JTS Allgemeine Java-Themen 5
S Java Design Frage Allgemeine Java-Themen 10
E Reflection? Frage Allgemeine Java-Themen 4
C FileInputStream frage Allgemeine Java-Themen 6
G Polymorphie Programmdesign Frage Allgemeine Java-Themen 20
Uzi21 Frage zu NetBeans ( Console) Allgemeine Java-Themen 11
D Classpath Frage zum Java Resource Loading Allgemeine Java-Themen 2
G Frage zu JPA Allgemeine Java-Themen 1
S Methoden Frage Allgemeine Java-Themen 2
P MVC - Frage zu Model Allgemeine Java-Themen 4
K Frage zu Locks Allgemeine Java-Themen 1
S Frage zu abstract Allgemeine Java-Themen 5
M ArrayList<String> Frage Allgemeine Java-Themen 7
M OOP Design Frage Allgemeine Java-Themen 2
N Frage zur while-Schleife Allgemeine Java-Themen 18
T Best Practice Auslesen von Zeichenketten (Frage, Antworten, usw) Allgemeine Java-Themen 4
C Eine Frage zur Bearbeitungszeit Allgemeine Java-Themen 8
H Frage wegen Heap-Speicher Allgemeine Java-Themen 2
T Garbage Collection Frage Allgemeine Java-Themen 15
P Kurze Frage: aus einer File die Zeilenanzahl auslesen Allgemeine Java-Themen 9
D Frage zu Java und Umlauten / charsets Allgemeine Java-Themen 2
B Frage zu Java und OpenGL? Allgemeine Java-Themen 3
Q Kapselung Allgemeine Design- Frage Allgemeine Java-Themen 8
DStrohma LayoutManager Frage zum GridBagLayout Allgemeine Java-Themen 4
F Frage zu Regex möglich Allgemeine Java-Themen 4
H XML-File mit Java erzeugt Frage Allgemeine Java-Themen 10
D Frage und Antwort Programm, Problem bei Methodenaufruf Allgemeine Java-Themen 3
J NetBeans Frage bezüglich der Scanner-Klasse Allgemeine Java-Themen 6
H Java Vector Frage Allgemeine Java-Themen 9
W Frage... Allgemeine Java-Themen 29
R Frage zur topologischen Sortierung Allgemeine Java-Themen 2
H Frage zu weka.core.Instance Allgemeine Java-Themen 3
Y Kleine Frage zu String.split Allgemeine Java-Themen 3
T Frage zu Klassendesing Allgemeine Java-Themen 3
W Frage zu Refactoring statischer Methoden Allgemeine Java-Themen 4
C Eclipse Wichtige frage Allgemeine Java-Themen 5

Ähnliche Java Themen

Neue Themen


Oben