Hi Community!
Ich habe vor einiger Zeit eine
SOAP-Server-Anwendung mit inzwischen 3 versch. zugehörigen Clients erstellt.
Der Server besteht aus 5 Units:
1. Implementation-
Unit
2. Interface-
Unit
3. WebModule +
Unit
4. und 5. sind eigene Units mit Funktionen und Prozeduren, die von den Server-Methoden benutzt werden
Mein Problem ist:
Ich weiß nicht genau, wie Delphi intern mit mehreren "gleichzeitig" ankommenden Client-Aufträgen umgeht.
Werden dafür Threads generiert?
Wenn ja, müsste es beim Aufruf der Funktionen/Prozeduren der Units 4 und 5 zu Problemen kommen, da ich kein Synchronize verwende.
Aber synchronize benutzt man ja nur, um (selber generierte) Threads mit dem Hauptthread zu synchronisieren. Ich habe ja aber keinen Hauptthread in dem Sinne..
Auch das Schreiben in ein und das gleiche LogFile müsste zu Konflikten führen..
Um das zu testen habe ich den Server mal bombardiert:
Habe 20 mal eine 117MB große Datei geschickt, 20 mal eine 85MB große Datei und 50 mal eine 11MB große Datei. Dabei ist zwar nicht gesagt, dass Konflikte, die evtl. auftreten könnten, tatsächlich auftreten, aber mir schien es ein gutes Test-Scenario zu sein.
Der Test endete damit, dass der IIS abgeschmiert ist, weil er alle ankommenden SOAPAttachments in ein auf C: liegendes Temp-Verzeichnis ablegt, diese dort aber niemals löscht.. Neustarten ließ sich der IIS nach dem Bereinigen der Platte auch nicht, so dass mein Test eine Neuinstallation des IIS nach sich zog, mir aber keine Informationen geliefert hat..
Alternativ könnte ich mir auch vorstellen, dass der Server auf dem spezifizierten Port lauscht und wenn etwas kommt, einen Prozess von sich selbst startet. Kommen also 10 Client-Aufträge rein, werden 10 Server-Prozesse meines Servers gestartet, so wie wenn man beispielsweise Delphi 2 mal startet. Dann würden Aufrufe der Funktionen/Prozeduren der Units 4 und 5 kein Problem darstellen, sondern nur die Speicherung des Logs in der gleichen Datei. Wenn dem so ist, dann müsste ich die Prozesse ja im Taskmanager des Rechners, auf dem der IIS installiert ist, sehen, oder? Werde darauf mal achten, sobald der IIS wieder flott ist.
Vielleicht funktioniert das intern aber auch ganz anders? Die Funktionen und Prozeduren, die der Server dem Client zur Verfügung stellt, sind ja Methoden einer Klasse. Diese Klasse wird vom Client instanziert, um die Methoden benutzen zu können. D.h. jeder Client-Auftrag läuft im Endeffekt mit einer anderen Instanz der Server-Klasse. Aber im Endeffekt klingt das auch wieder nach Threads.. Die Frage ist halt, wie ich Konflikten vorbeuge, etwa wo ich CriticalSections benutze etc
Also Frage zusammengefasst:
1 Client-Auftrag =
a) 1 neuer Thread
b) 1 neuer Prozess der Server-Applikation
c) etwas ganz anderes
Ich hoffe, ich konnte mich einigermaßen verständlich ausdrücken.
mfg
hyype