synchronisation einer Methode abhängig vom Parameter

Status
Nicht offen für weitere Antworten.
S

spoofs

Gast
Hallo allerseits,

cih brüte schon eine ganze Weile über einem Problem bei meiner Webanwendung. Und zwar soll der Benutzer bestimmte Dateien über einen Cache abgreifen können, diese Dateien müssen aber erst generiert werden. Das ganze läuft so ab dass bei einer Anfrage geguckt wird ob die Datei bereits im Cache liegt, wenn ja dann benutzte sie, sonst generiere sie und packe sie in den Cache und benutze sie dann.

Mein Problem liegt nun darin das das Generieren der Datei ca. 2-3 Sekunden dauert. Sprich der erste Benutzter fordert die Datei an -> sieht sie liegt nicht im Speicher und beginnt mit der Generierung, welche mit dem Speichern im Cache endet. In der Zwischenzeit (während die erste Anfrage noch am generieren ist) kommt eine zweite Anfrage DIESELBE Datei zu abzugreifen. Es wird in den Cache geguckt ob die Datei da ist (ist sie natürlich noch nicht weil der erste noch am generieren ist) und so beginnt der zweite dieselbe Datei zu generieren und die vom ersten geschriebenen zu überbügeln.
In der Zwischenzeit will der erste (der ja weiß das die Datei im Cache ist, weil er die gerade selber da reingepackt hat) die Datei weilterbenutzten bekommt jetzt aber irgendeinen unvollständigen Müll weil der zweite gerade rausschreibt.

So nun mal zu der Methode: Sie hat als Parameter nur die Dateinamen (Inputfiles und das Resultfile) als String. Achtung: daran kann ich auch nichts ändern! Das muß so bleiben.
Pseudo läuft das ganze so ab:
Code:
public static void generateAndCacheFile(String infile1, String infile2, String resultfile){

   if(!isCached(resultfile)){
       //starte mit dem generieren
       generateFile(infile1,infile2,resultfile);
   }
}

Ich kann das Problem umgehen wenn ich die Methode synchronized setzte. Das hieße aber das alle Anfragen (egal welche Datei) warten müßten, bis die vorherigen fertig sind. Das wird unter Last aber nicht funktionieren und das Ganze wahnsinnig langsam machen.

Deswegen würde ich gerne den Inhalt der Methode abhängig vom übergebenen "result"-Filenamen synchronisieren.

Ich hab das ganze mal probeweise so umgesetzt:

Code:
private static Arraylist lockedFilenames;
...

public static void generateAndCacheFile(String infile1, String infile2, String resultfile){

  while(lockedFilenames.contains(resultfile)){
    //warte einfach
  }
  
  lockedFilenames.add(resultfile);     //Dateinamen sperren


   if(!isCached(resultfile)){
       //starte mit dem generieren
       generateFile(infile1,infile2,resultfile);
   }

  lockedFilenames.remove(resultfile);    //Dateinamen wieder freigeben
}

Da ich mit Synchronisierung aber noch nichts gemacht habe weiß ich nicht ob das so geht bzw. ich bezweifele das das optimal ist (obwohl es funktioniert), denn muß ich dann nicht auch den Zugriff auf lockedFiles synchronisieren? Und habe ich dann nicht das selbe Problem das alle warten müssen bis lockedFiles wieder freigegeben wird?

Ich weiß echt nicht wie ich das umsetzten soll, ich kann kaum was ändern am vorhandenen Code. Das die Generierung der Datei 2-3 Sekunden dauert ist normal, da es ein mehrstufiger komplexer Prozeß ist bevor die Datei rausgeschrieben werden kann. Ist es nicht irgendwie möglich die Methode bezogen auf den resulfile-Namen zu sperren und entsperren?
Hoffe ihr habt ein paar vorschläge für mich, brüte da schon ne ganze Weile drüber. Im Prinzip müßte ich mir global merken welche Dateien gerade geprüft/generiert werden und dementsprechend bei Doppelanfragen sperren oder freigeben. Das ist ja das was ich da oben mikt meinem Ansatz versuche aber ich weiß nicht ob das sinnvoll ist, bzw ob es besser geht.

Danke für die Geduld,
spoofs
 

AlArenal

Top Contributor
Ich hab mal weiter oben mit Lesen Halt gemacht und frage:
Warum setzt du, wenn du gerade Datei x generieren lässt, für diese kein Flag "wird generiert", so dass eine zwischenzeitliche Anfrage weiß, dass sie die Generierung nicht neu anstoßen muss, sondern wartet bis der Vorgang zu Ende ist (Flag nicht mehr gesetzt)?

P.S.:
Würde doch schon reichem die Zieldatei nicht direkt zu schreiben, sondern erst in eine Datei x.tmp in den Cache zu setzen. Auf das Vorhandensein dieser Datei kann man entsprechend prüfen und wenn die Generierung fertig ist, benennst du sie um in x.
 
G

Guest

Gast
Hallo,

wenn du weitergelesen hättest, dann wüßtest du das ich das mit dem "Flag" so in etwa versuche umzusetzten, nur weiß ich nicht ob das ok so ist...

das mit der tmp, wäre ne idee, aber da muß ich die anderen anfragen auch irgendwie "warten" lassen bevor sie weiter machen dürfen.

gruß,
spoofs
 
S

spoofs

Gast
Hallo,

ja das stimmt schon, ich frage mich nur in wie fern das noch performant ist. Geht das mit der globalen MerkListe so wie ich mir das denke? Muß ich den Zugriff synchronisieren?

Ich habe leider noch keine Erfahrung mit derartigen Probleme gemacht deswegen frage ich. Die Lösung mit der Liste ist besser als wenn ich die ganze Funktion synchronisiere, denn dann müssen nur gleiche anfragen warten...oder sehe ich das falsch?

gruß,
spoofs
 
G

Guest

Gast
spoofs hat gesagt.:
Hallo,

ja das stimmt schon, ich frage mich nur in wie fern das noch performant ist. Geht das mit der globalen MerkListe so wie ich mir das denke? Muß ich den Zugriff synchronisieren?

Ich habe leider noch keine Erfahrung mit derartigen Probleme gemacht deswegen frage ich. Die Lösung mit der Liste ist besser als wenn ich die ganze Funktion synchronisiere, denn dann müssen nur gleiche anfragen warten...oder sehe ich das falsch?

gruß,
spoofs

Definier die Methode synchronized. Die Kosten sind echt verschwindend gering. Wie lange kann es dauern, das
Objekt aus dem Cache zu finden und zurück zu liefern? Wie viele Milliarden Anfragen pro Sekunde willst
Du verarbeiten können?
Mach es zuerst mal richtig, wenn es dann Performanceprobleme gibt, kann man immer noch optimieren.
tfa
 
S

spoofs

Gast
Hallo nochmal,

wie bereits oben beschrieben habe ich die Methode bereits synchronized gehabt und bin der Meinung dass das keine Option ist, denn die Anwendung lebt von der ständigen Generierung von den Dateiobjekten und diese Dateien sind sehr groß. Es wird später sehr viel Nutzer geben. Daher halte ich es nicht für sinnvoll jede Anfrage warten zu lassen, die irgendeine Datei holen will sondern nur die Anfragen die die selbe Datei wollen.

Meine Frage ist ja nur wie man sowas mit nem Dateinamen-Merker am besten realisiert bzw. wie läßt man (technisch) am besten einen Anfrage warten? Ist das okay so mit der while Schleife? muß ich die statische ArrayList synchronisieren? Oder gibt es generell ne bessere Lösung.

gruß,
spoofs
 

KSG9|sebastian

Top Contributor
Gast hat gesagt.:
Definier die Methode synchronized. Die Kosten sind echt verschwindend gering

Na das stelle ich doch mal sehr in Frage...die VM hängt an jede synchoronized-Methode einen Monitor dran. Jenachdem kostet das sehr wohl Performance. Wieviel muss halt geschaut werden.
 
S

spoofs

Gast
Ebend, ich sehe das genauso, dass das sehr wohl auf die Performance geht, besonders wenn 100 Leute gleichzeitig Dateien generieren...

Hat denn keiner eine Idee bzw. ist das so wie ich mir das da oben mit der ArrayList gedacht habe sinnvoll?
:bahnhof:

Bin für alle Tips dankbar.

gruß,
spoofs
 
S

spoofs

Gast
Hallo allerseits,

ich nutze diesen Fred mal weiter...

also ich hab mich jetzt dafür entschieden eine temporäre Datei als eine Art Flag anzulegen. Das Ganze mache ich so:
Code:
File file = new File(result_filename+".tmp");

while(file.exists()){
  //wait        <---- wie?
}

file.createNewFile();
...
eigentliche Generierung
...
file.delete();

Jetzt frage ich mich (das ganze passiert in einem Servlet), wie man das warten üblicher Weise realisiert. Einfach eine leere Schleife? Aber ist es nicht sagen wir mal unperformant permanent zu fragen ob die Datei existiert? Wie realisiert ihr das im Normalfall?

Danke,
spoofs
 

schalentier

Gesperrter Benutzer
Thread.sleep(..) koennte helfen, aber in einem Servlet ist das wohl ein wenig schlecht ;-)

Ich wuerde anstatt der Warteschleife ein HTML ausliefern, was dem Benutzter sagt, dass es grad etwas dauert. Ein Timer mit Reload im HTML ruft dann nach ein paar Sekunden die Seite erneut auf, dann ist der Generator hoffentlich fertig (ansonsten nochmal die Warteseite anzeigen).

Kannst du das Generieren vielleicht sogar komplett aus den Servlets auslagern und irgendwie als Backgroundtask laufen lassen? Ich denke, lange Prozesse in einem Servlet sind eher unguenstig irgendwie.

Aber zur Not gehts auch mit einem sleep(..) in der while-Schleife...

mfg
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Synchronisation einer Textdatei im Groupshare Allgemeine Java-Themen 1
F Bluetooth / Synchronisation : Problem mit einer Bluetoothanwendung Allgemeine Java-Themen 3
G Synchronisation nicht statischer Methoden Allgemeine Java-Themen 4
R Threads korrekte Synchronisation bei Vector und ArrayList Allgemeine Java-Themen 6
K Threads - Swing - Synchronisation nötig? Allgemeine Java-Themen 8
K Thread Synchronisation Allgemeine Java-Themen 8
T Synchronisation von Listen bei Zugriffen durch mehrere Prozesse Allgemeine Java-Themen 15
T Project Synchronisation Allgemeine Java-Themen 4
B Ausgabe auf der Konsole bei Nebenläufigkeit, Threads und Synchronisation Allgemeine Java-Themen 8
B Nebenläufigkeit, Threads und Synchronisation Allgemeine Java-Themen 10
R Konzept eines Software-Rollout/Synchronisation via WebService Allgemeine Java-Themen 5
H Thread Synchronisation. mutex.lock(); und mutex.unlock(); Allgemeine Java-Themen 4
S Synchronisation von Threads Allgemeine Java-Themen 7
T problem mit synchronisation Allgemeine Java-Themen 4
G Links zum Thema Synchronisation Allgemeine Java-Themen 7
H LRUMap und Synchronisation Allgemeine Java-Themen 5
F Synchronisation + Vector/ArrayList/LinkedList Allgemeine Java-Themen 7
S Threads und Synchronisation Allgemeine Java-Themen 3
A Synchronisation Datenquelle und Anwendung (Multi-User) Allgemeine Java-Themen 7
A Daten-Synchronisation Client <-> Datenquelle (DB) ? Allgemeine Java-Themen 6
C Synchronisation aber trotzdem parallel lesen Allgemeine Java-Themen 2
O Text aus einer Textdatei rausholen, der zwischen zwei Schlüsselworten steht Allgemeine Java-Themen 4
V Umgang mit fehlenden Daten in einer Java-Datenanalyseanwendung Allgemeine Java-Themen 5
M Methodenübersicht einer Klasse einsehen Allgemeine Java-Themen 14
T JNA, Aufruf der Funktionen einer dll Allgemeine Java-Themen 5
I Vom Monolith zu Services in einer Webseite Allgemeine Java-Themen 1
W Variable Initialisierung mit dem Ergebnis einer Regex Allgemeine Java-Themen 1
O Werte einer Generic LinkedList zusammenrechenen Allgemeine Java-Themen 14
C Sortieren und Selektieren einer ArrayList<Point3D> Allgemeine Java-Themen 6
A Einzelne Objekte und Unterobjekte einer ArrayList ausgeben Allgemeine Java-Themen 53
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B Ein Objekt einer Klasse mehreren anderen Klassen zur Verfügung stellen? Allgemeine Java-Themen 6
M Optimierung einer Methode (byte-Geraffel) Allgemeine Java-Themen 2
I Wie kann ich den Wert aus einer If abfrage ausgeben Allgemeine Java-Themen 23
S HTML einer Webseite 1:1 so bekommen wie es auch der Browser anzeigt? Allgemeine Java-Themen 14
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
L Java überprüfen lassen, ob sich ein gegebener Pfad / das Programm an sich auf einer CD oder Festplatte befindet Allgemeine Java-Themen 14
J (Geplante) Änderungen an einer Datei vorübergehend speichern und anwenden? Allgemeine Java-Themen 12
ME2002 Fragen aus einer Java Klausur Allgemeine Java-Themen 67
_user_q Obfuscate einer .jar-Datei mit ProGuard? Allgemeine Java-Themen 2
_user_q Verknüpfung einer .jar-Datei (liegt z. B. auf dem Desktop) im Autostart-Ordner erstellen? Allgemeine Java-Themen 20
C Parsen einer sich updatenden Html mithilfe von jsoup Allgemeine Java-Themen 4
E Eine Methode einer extendeten Klasse deakitivieren Allgemeine Java-Themen 12
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
LimDul Kam eine java.net.URL zu einer HashMap und ging als DNS Anfrage wieder heraus Allgemeine Java-Themen 18
E Variablen Nach Übergabe einer Variable den Constructor aufrufen Allgemeine Java-Themen 16
Zeppi NullPointerException in einer if-Abfrage Allgemeine Java-Themen 6
D Abbruch einer ViewScoped Bean in Arbeit Allgemeine Java-Themen 2
Lukas2904 Schleife mit ansteuerung einer Klasse Allgemeine Java-Themen 5
d.lumpi Aus Einer Klasse auf ein Objekt einer anderen Klasse Zugreifen Allgemeine Java-Themen 1
Lukas2904 Wie kann man cps (ClicksPerSecond) in einer GUI anzeigen lassen? Allgemeine Java-Themen 4
O Produziert das Tool "jpackage" (ab JDK 14) .exe Dateien, die auf einer Zielumgebung ohne JRE lauffähig sind ?` Allgemeine Java-Themen 7
R Lambda Expression in einer Methode execute() aufrufen (execute() ist eine Methode aus dem funktionalen Interface Command) Allgemeine Java-Themen 5
Drachenbauer wie kann ich alle instanzen einer Klasse durchsehen, ohne, dass diese in einer Liste erzeugt wurden? Allgemeine Java-Themen 11
N BlueJ Implementation einer Analoguhr Allgemeine Java-Themen 0
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
N Speicherort einer Datei im Explorer ändern Allgemeine Java-Themen 8
O Datentypen Wie kann ich den Typ einer ArrayList abfragen ? Allgemeine Java-Themen 7
O Leerzeichen und Umlaute im Pfad einer Java Applikation machen Probleme Allgemeine Java-Themen 13
H Mehrere PNG-Files in einer Datei Allgemeine Java-Themen 9
G Java Editor Löschen doppelter Zahlen einer Liste Allgemeine Java-Themen 2
J JSON Daten von einer Webseite erhalten Allgemeine Java-Themen 2
L RegEx für Teile einer Berechnung Allgemeine Java-Themen 14
L Erste Schritte TDD testen einer Methode mit injezierten Services? Allgemeine Java-Themen 12
J Zerlegen einer Zahl Allgemeine Java-Themen 6
Zrebna Wie kann man endgültig aus einer Rekursion ausbrechen? Allgemeine Java-Themen 14
MiMa Person in einer Arraylist hinzugügen mit Prüfung ? Allgemeine Java-Themen 6
Meeresgott Effizientester Weg um nach der Value einer verschachtelten Map aufzulösen Allgemeine Java-Themen 5
H Mehrere Datentypen in einer Arraylist speichern Allgemeine Java-Themen 9
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
MiMa Erstellungsdatum einer Datei Allgemeine Java-Themen 10
Drachenbauer Wie kann ich einer existierenden Enum von außerhalb veränderte Werte zuweisen? Allgemeine Java-Themen 5
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Rückgabe einer HttpURLConnection für eine Seite einlesen bei der man eingeloggt ist..? Allgemeine Java-Themen 5
O Java-Applikation tut in Netbeans, als JAR nicht, wegen Pfadangaben einer benötigten Datei Allgemeine Java-Themen 8
M Hilfe bei einer Java Programmieraufgabe! Ab morgen Montag um 08:00 Uhr Allgemeine Java-Themen 5
J Algorithmen Analyse einer Schleife Allgemeine Java-Themen 6
Drachenbauer Wie finde ich den Aufrufer zu einer Methode, die sich nicht in meinem Projekt befindet? Allgemeine Java-Themen 2
J Die Letzte Zahl aus einer Text datei lesen Allgemeine Java-Themen 8
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
A Mithilfe von einer Nummer einen Namen finden n-Beziehung Allgemeine Java-Themen 8
Scream_ilias Auf einer Website die anmeldedaten eingeben Allgemeine Java-Themen 9
V Threads Probleme beim Aufrufen von Methoden einer anderen Klasse (Threads) Allgemeine Java-Themen 14
I Lohnt sich heutzutage der Aufwand einer Portierung für MacOS Allgemeine Java-Themen 8
J Suchen von einer Scannereingabe in einem HashSet Allgemeine Java-Themen 1
M Konstruktor einer Methode Allgemeine Java-Themen 35
L Echtzeitdaten aus einer Webseite ziehen mit Java Allgemeine Java-Themen 19
V EMail, Attachments auslesen von einer Email Allgemeine Java-Themen 0
T Google Links in einer Liste Allgemeine Java-Themen 4
T Sinn einer toString Methode Allgemeine Java-Themen 3
P Durchlaufen einer Queue Allgemeine Java-Themen 9
J Größe einer CD ermitteln Allgemeine Java-Themen 10
L Operatoren Java Reflections: Alle Methoden einer Klasse aufrufen ohne Exceptions Allgemeine Java-Themen 5
H Länge einer verketteten Liste Allgemeine Java-Themen 4
B Quellcode einer Java libary finden um zu copy & paste'n Allgemeine Java-Themen 5
N Daten einer JCoTable in JTextArea anzeigen Allgemeine Java-Themen 7
sascha-sphw Java 9 module Zugriff auf eine resource einer anderen JAR Allgemeine Java-Themen 0
N Generic Type einer Generischen Klasse während der Laufzeit bekommen Allgemeine Java-Themen 2
E Erstellen einer Liste mit einer maximalen Menge an Elementen Allgemeine Java-Themen 13
M Wie kann ich ein int[] Array in einer Methode benutzen? Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben