Concurrency Frage

PollerJava

Top Contributor
Hallo,

ich habe folgendes Problem. Ich hab eine Webanwendung, in der man im Frontend einen Button klickt und im Backend werden dann SMS verschickt. Wenn das verschicken erfolgreich war, dann soll ein Eintrag in die DB gemacht werden, wenn nicht natürlich auch.

Meine Frage wär jetzt, wie ihr das machen würdet.
Einen eigenen Thread im Backend öffnen und dort das Senden abhandeln, das hab ich jetzt schon gemacht - damit das Frontend nicht einfriert.
Ich frag mich jetzt, ob ihr für jede SMS einen Thread erzeugen würdet und ob ihr das schreiben in die DB im Thread machen würdet oder gibts da eine bessere Idee (Callback oder so)

Vielen Dank für Hinweise
lg
Poller
 

ceving

Aktives Mitglied
Ich frag mich jetzt, ob ihr für jede SMS einen Thread erzeugen würdet und ob ihr das schreiben in die DB im Thread machen würdet oder gibts da eine bessere Idee (Callback oder so)

Was soll denn ein SQL-Callback sein?

Abgesehen davon, dass dein Ansatz völlig einleuchtend ist und mir nicht ganz klar ist, was denn das Problem ist, dass du zu lösen versuchst, da du ja schon eine Lösung hast, wäre die einzige Alternative einen Java-Trigger zu schreiben.

Mit Oracle geht das so: PL/SQL Triggers

Das klappt aber nur mit pure Java also kein NMI.

In dem Fall würde sich aber die Reihenfolge der Aktionen umkehren. Es würde erst in die Datenbank geschrieben und danach würde im Trigger die SMS verschickt. Das hätte den Vorteil, dass der Eintrag in die Datenbank nur eingetragen würde, wenn die SMS erfolgreich war. Im Falle eines Fehlers würde der COMMIT fehlschlagen und es würde kein Müll in der Datenbank stehen.

Eine Datenbank hat von Hause aus Transaktionen während man was ähnliches in Java nur mit extremen Aufwand realisieren kann.
 

Tobse

Top Contributor
Ich verstehe die Frage auch nicht so recht... Button wird gedrückt => Thread starten => SMS schicken => in DB schreiben => Feedback an den Nutzer.
Einen Thread zu haben, der alle SMS schickt ist zwar möglich aber macht nur unnötig aufwand. Dann musst du Listener ergistrieren und den ganzen Kram; der Thread selbst lebt ja nur sehr kurz und sollte für das System kein Problem sein.
 
Zuletzt bearbeitet:

PollerJava

Top Contributor
Stimmt, ich hab meine Fragen vielleicht nicht klar genug formuliert.
Hier wären nochmal meine Fragen:

1. 10 SMS verschicken -> soll ich das mit 10 eigenen Threads neben dem main- Thread machen oder mit einem zusätzlichen Thread

2. wie würdet Ihr das Feesback zum Nutzer machen. Soll ich im Frontend z.B. alle 10s einen AJAX request machen, der im Endeffekt in die Datenbank schaut oder gibts da was besseres (außer Websocket, das hab ich mir schon angesehen - kann ich nicht verwenden, da ich eine definierte App Server Umgebung hab, welche WebSockets nicht unterstützt)

Ich bin deshalb unsicher, weil ich auch immer wieder im Kopf hab, dass Spring (ich verwende Spring) einen QuarzJib bietet, der mir zyklisch über eine Abarbeitungs- Tabelle laufen könnte und schauen könnte, was zu machen ist.
Problem wär dann halt wieder die Notifizierung an den Nutzer - vielleicht könnte ich das wieder mit AJA machen, die Testbarkeit ist aber eher schwierig.

Wär dankebar für weitere Anregungen in diese Richtung.
lg
Poller
 

Tobse

Top Contributor
Ich würde pro Nutzer einen Thread machen. Sendet ein Nutzer 1 SMS => Thread für 1 SMS. Sendet ein Nutzer 100 => 1 Thread sendet 100 SMS.

Was das Feedback "20/50 SMS versendet" angeht: Das kannst du - ausser mit Websockets - nur über AJAX polling lösen. Aber Die AJAX Schnittstelle muss ja nicht in die DB schauen sondern die kann ja auch beim Sende-Thread nachfragen, wieviel er schon geschickt hat.
Es gäbe auchnoch Long-Lived HTTP Requests . Aber da SMS versenden relativ zackig geht sollte das bei dir nicht notwendig sein.
 

PollerJava

Top Contributor
Danke für die Rückmeldung,
Es sind ja Microservices momentan extrem im Gespräch,
Ich hab mir überlegt, ob ich nicht eine zweite *.war mache, die nur für das versenden zuständig ist und diese war von einer anderen war über REST anspreche. Dann würd ich mir einen Thread in meiner jetzigen war ersparen und hätte automatisch 2 Prozesse -> je einer in war eins und einer in war zwei - wobei ich mir da gar nicht sicher bin - ist das so, dass z.B. JBoss je einen Prozess für ein war öffnet/erzeugt?

Was sagt ihr dazu - zu den Prozessen und der Architektur, diese Architektur würde mir sehr gut gefallen.
 
Zuletzt bearbeitet:

PollerJava

Top Contributor
Button wird gedrückt => Thread starten => SMS schicken => in DB schreiben => Feedback an den Nutzer..

Dazu hätte ich noch eine Frage. Würdest du das schreiben in die DB in dem Thread machen, bzw. geht das eigentlich problemfrei (mit dem Session Pooling von Hibernate usw.) oder sollte man das woanders machen, z.B. nach dem Versenden im Main-Thread (was ja dann wieder nichts bringen würde, da ich auf das Ende der Abarbeitung im Thread warten müsste)

Vielen Dank für die Hilfe.

lg
Poller
 

Tobse

Top Contributor
Du sagtst es ja schon. Im Main Thread gehts nicht. Welche Möglichkeit bleibt dir denn als der Versende-Thread? Und ich sehe eine Ursache, warum der nicht in die DB schreiben könnte.
 

arilou

Bekanntes Mitglied
Wenn's sehr auf Rechenzeit/niedrige Serverlast ankommt, kann man versuchen zu vermeiden, immer wieder neue Threads zu starten (sondern z.B. bereits vorhandene erneut zu nutzen); ebenso mit Datenbank-Connections.

Ansonsten: Denk' auch an deine Arbeit(szeit). 2 Wochen am "Beschleunigen und Schöner-Machen" rumgedoktort, kostet deinen Arbeitgeber mehr, als wenn er die nächsten 5 Jahre ein bischen mehr Serverpower einkauft...
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Verstaendnisfragen zu Concurrency Allgemeine Java-Themen 3
P Threads BufferedImage, Thread Concurrency Allgemeine Java-Themen 1
Kr0e Java, Concurrency und Synchronisierung Allgemeine Java-Themen 4
S Concurrency access auf eine Map Allgemeine Java-Themen 6
G multithreading, concurrency conveyor belt beispiel Allgemeine Java-Themen 2
O Multithreading mit Java 5 u den Concurrency APIs Allgemeine Java-Themen 7
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
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
A eine test thread.join() frage Allgemeine Java-Themen 2
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


Oben