Komplexes Reporting Problem

Status
Nicht offen für weitere Antworten.

chuanito

Mitglied
Halli hallo,

Ich bin gerade daran eine Reporting Engine für eine internet Logistik Applikation zu konzepieren.

Die Reports, meistens nur ein Report, wird aus mehreren Tabellen erstellt die jeweils bis zu 6Mio
Records haben.

Diese Daten wiederum haben aber immer ein "Last Updated"-Feld womit nicht immer die ganzen
Daten eingelesen werden müssen.

Welcher Ansatz wäre von euch her interessant und um das Problem zu lösen.

Ich habe mir da einige Gedanken zu einem ReportManger gemacht, der mehrere Threads aufmacht
und dann die SQL Statements absetzt. Es werden nicht einfach Felder ausgelesen sondern die Applikation
muss eine gewisse Bussiness Logic einbringen...z.B

Um zu berechnen ob eine Fracht angekommen ist, werden gewisse Status-Nachrichten auf ihre Abhängigkeiten
überprüft und dann als "Noch offen" oder "Am Ziel-Ort" angekommen markiert.

Der Schlüssel für diese Berechnungen sind immer die Fracht ID's die jeweils eine Sendung representieren.

Um zu verhindern, dass die Report Engine mit mehreren Threads die gleiche Sendung verarbeitet werden
in der Reporting Tabelle gewisse Felder mit einem Boolean auf gelockt gesetzt und erst wieder de-lockt wenn
alle Sendungen durch sind.


Habt ihr Vorschläge wie ich die Aufgabe besser lösen kann?
 

Bleiglanz

Gesperrter Benutzer
Ich habe mir da einige Gedanken zu einem ReportManger gemacht, der mehrere Threads aufmacht
und dann die SQL Statements absetzt.
das bringt i.A. gar nichts, wozu "mehrere Threads"?

Um zu verhindern, dass die Report Engine mit mehreren Threads die gleiche Sendung verarbeitet werden
in der Reporting Tabelle gewisse Felder mit einem Boolean auf gelockt gesetzt und erst wieder de-lockt wenn
alle Sendungen durch sind.
das ist kompliziert, gefährlich (vergessene Locks) und bringt auch nichts, warum um alles in der Welt muss eine Zeile gesperrt werden nur weil gerade ein Report erstellt wird

ich würde ein Datawarehouse für Dummies verwenden und alle benötigten Daten z.B. in eine lokale embedded-DB (HSQL, Derby)
einlesen

oder du erstellst ein paar Views auf dem Server, die schon alles richtig aufbereiten
 

chuanito

Mitglied
das bringt i.A. gar nichts, wozu "mehrere Threads"?

Ganz einfach. in der Zeit wo ich eine Sendung (=Thread) berechne kann ich in der gleichen Zeit 4-5 ausrechnen,
da ich beim sequenziellen verarbeiten immer auf das Ende der Verarbeitung warten muss aber diese Sendungen
keine Verbindung zu einander haben.

das ist kompliziert, gefährlich (vergessene Locks) und bringt auch nichts, warum um alles in der Welt muss eine Zeile gesperrt werden nur weil gerade ein Report erstellt wird

ich würde ein Datawarehouse für Dummies verwenden und alle benötigten Daten z.B. in eine lokale embedded-DB (HSQL, Derby)
einlesen

oder du erstellst ein paar Views auf dem Server, die schon alles richtig aufbereiten

du hast mich falsch verstanden :) ich locke oder sperre keine Zeile die irgendwo in einer Applikation etc. gebraucht
wird. Ich ziehe mir die produktiven Daten, die für die Reports eine Rolle spielen in eine andere Tabelle und bearbeite sie dort.
 

AlArenal

Top Contributor
chuanito hat gesagt.:
das bringt i.A. gar nichts, wozu "mehrere Threads"?

Ganz einfach. in der Zeit wo ich eine Sendung (=Thread) berechne kann ich in der gleichen Zeit 4-5 ausrechnen,
da ich beim sequenziellen verarbeiten immer auf das Ende der Verarbeitung warten muss aber diese Sendungen
keine Verbindung zu einander haben.

Was soll denn da von wem berechnet werden? Wenn die Karre ausgelastet ist, weil sie irgendwas berechnet, ist sie nicht weniger ausgelastet, wenn sie gleichzeitig noch anderweitig Daten holen soll.

Wenn du wer-weiß-was-für-komplexe SQL-Abfragen abschickst, wird die DB auch nicht performanter, wenn du sie über mehrere Threads gleichzeitg mit mehreren solcher Anfragen belastest. Die Gesamtperformance sinkt um die Zeit, die für zusätzliche Synchronisationsmchenismen und Scheduling benötigt wird.

Schonmal von KISS gehört? Keep is simple, stupid ...
 

chuanito

Mitglied
Hmm nein es handelt sich dabei um 5-6 einfache SQL-Statements und das ganze läuft auf einem IBM Informix Server
(8-CPU-Rechner).
 

Bleiglanz

Gesperrter Benutzer
OK, wenn du 8CPUs hast dann machs mit Threads (wenn diese Leistung überhaupt erforderlich ist)

was genau ist denn dann das Problem

Haufen Threads
rechnest alles aus
erstellst den Report
Fertig
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
H Komplexes Rechnen mit Java Allgemeine Java-Themen 6
S TestNG Eclipse: Reporting erstellen/ verändern Allgemeine Java-Themen 0
C Crystal Report XI R2 Currently not implemented in the Java Reporting Component Allgemeine Java-Themen 2
A Monitoring und Reporting von Prozessen Allgemeine Java-Themen 2
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12

Ähnliche Java Themen

Neue Themen


Oben