23.11.2013 Aufrufe

Synchrone Kommunikation - The Distributed Systems Group

Synchrone Kommunikation - The Distributed Systems Group

Synchrone Kommunikation - The Distributed Systems Group

MEHR ANZEIGEN
WENIGER ANZEIGEN

Sie wollen auch ein ePaper? Erhöhen Sie die Reichweite Ihrer Titel.

YUMPU macht aus Druck-PDFs automatisch weboptimierte ePaper, die Google liebt.

Nachrichtenbasierte <strong>Kommunikation</strong><br />

- “Austausch” von Nachrichten: send → receive<br />

- Implizite Synchronisation: Senden vor Empfangen<br />

Empfänger erfährt, wie weit der Sender mindestens ist<br />

- Nachrichten sind dynamische Betriebsmittel:<br />

gegründet beim Senden, verbraucht beim Empfangen<br />

- Interprozesskommunikation - naive Sicht:<br />

Instruktionsfolge<br />

Zeit<br />

process P1:<br />

begin<br />

send (...)<br />

receive (...)<br />

end<br />

process P2:<br />

begin<br />

receive (...)<br />

receive (...)<br />

send (...)<br />

end<br />

- Welche <strong>Kommunikation</strong>sanweisungen “matchen”?<br />

- Empfangsbereitschaft, aber keine Nachricht?<br />

- Nachricht, aber keine Empfangsbereitschaft?<br />

- Sprachliche Ausprägung der <strong>Kommunikation</strong>?<br />

- Wie wird adressiert?<br />

==> Vielfältige Aspekte, Varianten, Probleme...<br />

?<br />

Vert. Sys., F. Ma. 84<br />

Message Passing System<br />

- Organisiert den Nachrichtentransport<br />

- Bietet <strong>Kommunikation</strong>sprimitive (APIs) an<br />

- z.B. send (...) bzw. receive (...)<br />

- ggf. auch ganze Bibliothek unterschiedlicher <strong>Kommunikation</strong>sdienste<br />

- verwendbar in gängigen Programmiersprachen (oft zumindest C)<br />

Verteilte Anwendung<br />

APIs<br />

System1 Netz System2 System3<br />

- Verwendet vorhandene Protokolle; implementiert ggf.<br />

damit neue Protokolle<br />

- Garantiert (abhängig von der “Semantik”) gewisse<br />

Eigenschaften<br />

- z.B. Reihenfolgeerhalt<br />

- Abstrahiert von Implementierungsdetails<br />

- wie z.B. Puffer, Low-level-Adressen etc.<br />

- Maskiert gewisse Fehler<br />

- z.B. durch automatische Wiederholung nach einem timeout<br />

- Verbirgt Heterogenität unterschiedlicher Rechnerbzw.<br />

Betriebssystemplattformen<br />

===> Portabilität!<br />

einfache Form von<br />

“Middleware”<br />

(→ später)<br />

- Besteht aus Hilfsprozessen,<br />

Pufferobjekten...<br />

- Verbirgt Details des zugrundeliegenden<br />

Netzes<br />

Vert. Sys., F. Ma. 85

Hurra! Ihre Datei wurde hochgeladen und ist bereit für die Veröffentlichung.

Erfolgreich gespeichert!

Leider ist etwas schief gelaufen!