Scheduling in JAVA EE

beta20

Top Contributor
Hallo zusammen,

ich habe eine Frage was das Scheduling in JAVA EE angeht.
Ich verwende als Applikationsserver WildFly.
In JAVA EE ist es möglich verschiedene Schedules einzurichten:
@Schedule

Es lässt sich auch einstellen, wie oft der Schedule laufen soll.
Soweit so gut - das funktioniert auch.

Meine größere Sorge ist nun aber:
- Ich habe eine Applikation und es sollen stündlich 10.000 Schedules, also demnach 10.000 Datenbankabfragen geschehen.

Kann das nicht zum Problem meiner DB werden?
Was kann man dagegen tun? Mehr RAM, mehr CPU etc. einrichten?

Prinzipiell kann man dazu sagen, dass das i.d.R. dann INSERT Statements sind.
Anschließend können noch weitere Aktionen durchgeführt werden:
- Email senden
- Payment Provider kontaktieren und Payment anstoßen
- ....

Anwendungsfälle sind:
1) Automatisierte Rechnungen
- Ich habe Kunden, die ein Abo abschließen
- Jeden Monat sollen alle Rechnungen automatisiert versendet werden.

2) Erinnerungen versenden
- Ein User richtet sich Erinnerungen ein.
- Eintrag in DB wird erstellt, dann die Erinnerung versendet wird
- Schedule läuft jede Minute und prüft, ob es ausstehende Einträge gibt
- Wenn ja: Email wird versendet
-> Problem hier: dies habe ich selbst ja nicht mehr im Griff. Ein User kann sich ja zig Erinnerungen erstellen...

Danke für Ratschläge
 

mrBrown

Super-Moderator
Mitarbeiter
Und wozu sind automatisiert minütlich 10.000 Datenbankabfragen nötig?
(Wenn die alle nacheinander laufen, darf jede grad mal 6ms dauert, das ist nicht grad viel Zeit...)
 

mrBrown

Super-Moderator
Mitarbeiter
Miss einfach mal, wie lange ein Datenbank-Request dauert, und dann überleg dir, wie das mit 10.000 aussieht.

Machbar ist irgendwie alles, irgendwann führt aber auch alles zu Performance-Problemen.
Lösen kann man das meist, in dem man das anders designed
 

beta20

Top Contributor
Ich glaube das updaten / insert in die DB wird eher nicht das Problem sein, sondern die Aktion die dann ausgeführt werden soll
- Email verschicken
- Angebot verschicken
- ....

Diese Aktionen dauern ja länger, als ein INSERT oder UPDATE....
 

mrBrown

Super-Moderator
Mitarbeiter
Miss einfach mal nach ;)

Wie kommst du denn auf 10.000? Du wirst wohl kaum 10.000 verschiedene hartcodierte Abfragen drin haben, vermutlich ist das N?
 
Zuletzt bearbeitet:

mihe7

Top Contributor
Es geht doch einfach nur um die Machbarkeit... Und ob das zu Performance Problemen führen kann bzw. was man dagegen machen kann....
Ja, eben. Dazu muss man sich ansehen: warum, was passiert, muss das so sein oder kann das weg? Geht es auch anders usw.

Die erste Erklärung war: 10.000 Schedules. Nehmen wir mal an, Du hättest Dich nicht verschrieben, sondern es wären wirklich 10.000 Schedules gewesen. Dann hätte man gesagt: WTF?!? Pack die 10.000 in eine "Runde".

Dann schreibst Du: 1 Schedule á 10.000 Aufgabenblöcke und das jede Minute. Die Frage: warum jede Minute?

Zweck: Prüfung ob Erinnerungen versendet werden müssen. Äh?!? Wozu brauchst Du 10.000 INSERTS um zu prüfen, ob Erinnerungen verschickt werden müssen? Und warum musst Du das minütlich prüfen?

Rein von der Machbarkeit: wenn die Grenzen eines Systems erreicht werden, lässt sich manches auf mehrere Systeme verteilen.
 

beta20

Top Contributor
Ok, also ich fasse es nochmal kurz zusammen, da es ja doch ein paar Verwirrungen gibt.

Beispiel: Erinnerungen versenden:
- Ich erstelle einen Termin und hake die Option an, dass ich z.B. 5h davor erinnert werden möchte
- Ich schreibe einen Eintrag in eine Tabelle (ScheduledObjects) mit dem plannedExecutionDate
- Mein Schedule (nur 1 Schedule!) prüft nun jede Minute, ob es Einträge in der Tabelle ScheduledObjects gibt, die fällig sind (plannedExecutionDate < currentDate)
- Wenn ja: dann wird eben z.B. eine Email versendet.

Wie ich nun entnehmen konnte, meint ihr, dass das Insert / Update NICHTdas Problem sein sollte

OK - wenn ich das richtig verstehe, dann könnte ich das dann auf mehreren Server verteilen?
- Also auf den Applikationsserver werden dann die Aktionen ausgeführt (zB. Email versenden)

Wo ich eher das bottleneck gesehen habe, war die DB ansich, da ich ja nur eine Datenbank habe.
Aber ich denke ihr habt Recht:
- Die Aktionen laufen ja dann eher auf dem Applikationsserver ab (Email versenden etc.)

Oder sehe ich es falsch?
 

mrBrown

Super-Moderator
Mitarbeiter
Ok, also ich fasse es nochmal kurz zusammen, da es ja doch ein paar Verwirrungen gibt.

Beispiel: Erinnerungen versenden:
- Ich erstelle einen Termin und hake die Option an, dass ich z.B. 5h davor erinnert werden möchte
- Ich schreibe einen Eintrag in eine Tabelle (ScheduledObjects) mit dem plannedExecutionDate
- Mein Schedule (nur 1 Schedule!) prüft nun jede Minute, ob es Einträge in der Tabelle ScheduledObjects gibt, die fällig sind (plannedExecutionDate < currentDate)
- Wenn ja: dann wird eben z.B. eine Email versendet.
Zumindest ich hab das auch so verstanden...

Die Frage ist allerdings immer noch, warum 10.000 Datenbank-Requests?

Wie ich nun entnehmen konnte, meint ihr, dass das Insert / Update NICHTdas Problem sein sollte
Wo konntest du das denn entnehmen? o_O


OK - wenn ich das richtig verstehe, dann könnte ich das dann auf mehreren Server verteilen?
- Also auf den Applikationsserver werden dann die Aktionen ausgeführt (zB. Email versenden)
Ja, wobei Verteilung auf mehrere Server immer auch manche Dinge komplizierter macht.

Wo ich eher das bottleneck gesehen habe, war die DB ansich, da ich ja nur eine Datenbank habe.
Aber ich denke ihr habt Recht:
- Die Aktionen laufen ja dann eher auf dem Applikationsserver ab (Email versenden etc.)

Die DB (bzw. das Netzwerk) *kann* je nach Latenz durchaus auch zum Bottleneck werden, wenn du 10.000 Requests nacheinander absetzt.
 

mihe7

Top Contributor
OK - wenn ich das richtig verstehe, dann könnte ich das dann auf mehreren Server verteilen?
Könntest Du, aber aktuell sehe ich aber noch keinen Grund dazu.

Das eigentliche Problem ist noch immer nicht identifiziert.

In welchen Zeitspannen werden wie viele Zeilen von Deinem SELECT geliefert? Gibt es zeitliche Verteilungen?

Wenn Du jetzt sagst, dass der SELECT jede Minute 10.000 Zeilen liefert und Du daher jede Minute 10.000 E-Mails rausschicken musst und das ganze 24 Stunden am Tag, dann wird es lustig, denn 14,4 Mio. Mails am Tag zu verschicken, könnte problematisch werden.
 

beta20

Top Contributor
Zumindest ich hab das auch so verstanden...
Die Frage ist allerdings immer noch, warum 10.000 Datenbank-Requests
Wo konntest du das denn entnehmen? o_O
Ja, wobei Verteilung auf mehrere Server immer auch manche Dinge komplizierter macht.
Die DB (bzw. das Netzwerk) *kann* je nach Latenz durchaus auch zum Bottleneck werden, wenn du 10.000 Requests nacheinander absetzt.

Es war nun nur einfach ein Beispiel mit 10.000 Requests.
Möglich wäre das z.B.

  • Anfang des Monats
    • -> 10.000 Rechnungen werden automatisiert verschickt
Dass jede Minute 10.000 DB-Requests stattfinden, ist natürlich auch übertrieben....
Aber ja, es kann zu so Spitzenzeiten kommen (wie oben: anfang des Monats)
 

mihe7

Top Contributor
Wenn Anfang des Monats 10.000 Rechnungen verschickt werden, dann passiert das doch nicht minütlich sondern einmalig. D. h. wenn Du um 00:00 Uhr 10.000 neue Rechnungen hast, hast Du um 00:01 Uhr keine neuen Rechnungen mehr (vermutlich um 01:00 Uhr immer noch keine). Du hast also Zeit ohne Ende.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Scheduling: "Quartz" verwenden, Hilfe bei Umstellung Java Basics - Anfänger-Themen 3
A thread scheduling Java Basics - Anfänger-Themen 3
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8
Tw1Z Erste Schritte Sort in java Java Basics - Anfänger-Themen 2
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben