Thread Sicherheit im komplexen Datenmodell

nocxsville

Bekanntes Mitglied
Hallo,

Ich habe ein (mehr oder weniger) komplexes Datenmodell im Speicher.
Das Datenmodell ist hierarchisch und umfasst zwischen 150.000 - 300.000 Objekte.
Auf das Datenmodell sollen diverse Module (ca. 7-10) aus verschiedenen Threads zugreifen.
Einige Module ändern in regelmäßigen Abständen (alle 250 ms - 1000 ms) Daten aus dem Modul. Andere ändern nur bei Bedarf und wesentlich seltener. Wieder andere greifen nur lesend zu. Die Datenänderungen sind im allgemeinen wenig zeit intensiv.

Meine Frage: Wie synchronisiere ich ein solches Datenmodell?

Ich habe bisher folgende Ideen:
(1) Über Locks in den einzelnen Typen.
Vorteil: Es werden nur die Daten gelockt, die geändert werden.
Nachteil: Das führt bei der Anzahl von Objekten zu sehr vielen Locks.

(2) Über eine zentrale Schnittstelle, über die alle Module zugreifen. Diese Schnittstelle hätte dann einen zentralen Lock.
Nachteil: Es wird immer alles gelockt, egal was geändert wird.
Vorteil: Nur ein Lock --> wenig Synchronisation-Aufwand.

(2a) Dispatch Thread (ähnlich wie in AWT/Swing):
Ein Thread der nacheinander Aufgaben (Event-Threads) abarbeitet.
Nachteil / Vorteil ähnlich wie (2) + Es werden viele Threads (Events) erzeugt.

Mich würden eure Erfahrungen interessieren.
Welche Lösung bevorzugt ihr (vielleicht eine ganz andere, die ich noch gar nicht bedacht habe)?

Vielen Dank im Voraus :)
 

diggaa1984

Top Contributor
Ist das teilweise auch synchron oder geht auch ausschliesslich asynchron?

Du könntest ja sagen wir mal 10 Threads haben, welche in einer Queue Anfragen zu Änderungen oder Lesezugriff annehmen. Jeder Thread arbeitet dann die Anfrage ab und sperrt das entsprechende Objekt. Würde wohl deinem vorschlag von 1 gleichkommen, aber bei der Anzahl an Threads sind die Locks ja beschränkt. Nachdem der Thread fertig ist gibt er das Dokument wieder frei.

Sollte ein Thread auf ein blockiertes Element stossen, kann er entweder warten, oder macht mit der nächsten Anfrage weiter. Das nicht bearbeitete Element bleibt in der Queue (entweder wieder hinten anstellen oder sofort erneut probieren).

Die Frage ist, ob die 10 Threads asynchron laufen dürfen, oder ob Änderungen auch synchroner Natur sein können/müssen. Aber auch da könnte man eventuell durch Anpassung des Models optimieren.
 

nocxsville

Bekanntes Mitglied
Die Module arbeiten komplett asynchron.
Die Variante 1 hat zudem den Nachteil, dass sehr viele Typen mit Locks ausgestattet werden müssen, was die Sache sehr komplex macht und wiederum zu Fehlern/Deadlocks führen kann.

Ich habe mir mal den Beitrag von "Graham Hamilton" zum Thema Multi-Threading in GUI-toolkits durchgelesen. Hier der Link: https://weblogs.java.net/blog/kgh/archive/2004/10/multithreaded_t.html

Natürlich sind GUI-Toolkits weitaus umfangreicher, den Kern trifft es aber ganz gut.
 

diggaa1984

Top Contributor
Was meinst du mit sehr viele Typen mit locks ausstatten. Ist die Klassenhierarchie derart vielseitig und nicht in einem oder mehreren super-Objekten lockbar?
Du lockst ja nur soviel Objekte gleichzeitig wie du Threads zur Verarbeitung benötigst.

Aber die Frage ist, was genau meinst du in der Aussage mit Typen?
 

nocxsville

Bekanntes Mitglied
Die Komplexität der Klassenhierarchie hält sich in Grenzen. Das Datenmodell besteht aber aus einer großen Anzahl verschiedener Typen.

Aus der Luft gegriffenes Beispiel für die Veranschaulichung:
Code:
Data Model <>--- Kunde <>---Bestellung <>---Status
                                       <>---Posten <>--- Katalog Item
                       <>---Notizen
           <>--- Typ A <>--- Typ B <>--- Bestellung
...

Fallbeispiele:
- Ein Modul fügt einen Posten zu einer Bestellung hinzu. In dem Fall müsste man die Bestellung locken.
- Ein Modul ändert Eigenschaften am Kunden (zum Beispiel den Namen). In dem Fall müsste man den Kunden locken.

Für die beiden Anwendungsfälle müsste man schon die Kunde- und die Bestellung-Klasse Thread-Sicher implementieren. Im Grunde lässt sich das endlos weiterführen. Auch wenn ich die Lösung mit den 10 Threads verwende, müsste ich doch nahezu jede Klasse Thread-Sicher implementieren. Ich habe ein ungutes Gefühl, eine solch große Zahl von Thread-Sicheren Klassen zu implementieren (auch wenn am Ende nur max 10 Locks gleichzeitig aktiv sind).

Daher meine Frage, wie andere dieses Problem gelöst haben. Favorit ist immer noch Lösung (2), wenn sie auch den Nachteil hat, dass das komplette Datenmodell bei jeder Änderung gelockt wird.
 
Zuletzt bearbeitet:

nocxsville

Bekanntes Mitglied
Mit Lösung (2) kann dann natürlich immer nur ein Thread gleichzeitig Änderungen vornehmen. Das hatte ich ja auch als Nachteil genannt.
Ja sage ja nur: "Die Module arbeiten komplett asynchron."
Das heißt nicht, dass sie auch asynchron Änderungen vornehmen. Mit Lösung (2) müssen die anderen warten.
 

diggaa1984

Top Contributor
Also wenn es Threadsicher sein muss, weil asynchron schreibend darauf zugegriffen werden muss, dann muss man wohl in den sauren Apfel beissen. Ob das Auslesen auch derart wichtig ist, dass man es blockt wenn eine Änderung läuft ist auch eine Frage die man beantworten sollte.

Kommt natürlich auf die Anwendungsfälle an.
Klassisches Beispiel ist ja immer: Synchronisierte Kontenführung (Einzahlen, Auszahlen)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
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
R ThreadPool - vorhandene thread liste überprüfen bzw. aufräumen Allgemeine Java-Themen 3
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
G JUnit Test Methoden in anderen Thread verlagern Allgemeine Java-Themen 4
P Java Probleme - java.lang.Thread.run(Unkown Source) Allgemeine Java-Themen 10
L Im Thread auf Eingaben warten Allgemeine Java-Themen 3
P aus Thread auf Form zugreifen Allgemeine Java-Themen 9
C Threads Thread blockieren Allgemeine Java-Themen 4
K Threads Thread für Sleep Allgemeine Java-Themen 6
H Threads Thread stirbt aber Objekte in ihm leben weiter?! Allgemeine Java-Themen 9
K Threads Thread aktualisiert Progressbar nicht Allgemeine Java-Themen 4
D Methoden Thread Schleife Status Allgemeine Java-Themen 7

Ähnliche Java Themen

Neue Themen


Oben