Instant Messaging: Difference between revisions

From
Jump to navigation Jump to search
Line 85: Line 85:
<table align="center" border="0" cellpadding="0"><tr><td>IM / GI </td><td>Entwickler</td><td>Erstes Release</td><td>Typ</td> <td>Toolkit</td><td>Aktuelle stabile Version</td> <td>Kosten</td></tr>
<table align="center" border="0" cellpadding="0"><tr><td>IM / GI </td><td>Entwickler</td><td>Erstes Release</td><td>Typ</td> <td>Toolkit</td><td>Aktuelle stabile Version</td> <td>Kosten</td></tr>
<tr><td>AOL IM</td> <td>AOL</td> <td>Mai 1997</td><td>Single Protocol</td><td>W32</td><td>5.1 (Win), 4.3(Mac)</td><td> kostenlos</td></tr>
<tr><td>AOL IM</td> <td>AOL</td> <td>Mai 1997</td><td>Single Protocol</td><td>W32</td><td>5.1 (Win), 4.3(Mac)</td><td> kostenlos</td></tr>
<tr><td>Yahoo!Messenger</td><td>Yahoo!</td><td> Jun.1999</td><td>Single Protocol</td><td>W32,7.0 (Win, 2.5.3 (Mac)Cocoas, 1.0.4-1 (Unix),4 FreeBSD, GTK</td><td>kostenlos</td></tr>
<tr><td>Yahoo!Messenger</td><td>Yahoo!</td><td> Jun.1999</td><td>Single Protocol</td><td>W32,7.0 (Win, 2.5.3 (Mac)Cocoas,1.0.4-1 (Unix),4 FreeBSD, GTK</td><td>kostenlos</td></tr>
<tr> <td>ICQ</td><td>Miarbilis</td><td>Nov.1996</td><td>Single Protocol</td><td>W32</td><td>5.06</td><td>kostenlos</td></tr>
<tr><td>ICQ</td><td>Miarbilis</td><td>Nov.1996</td><td>Single Protocol</td><td>W32</td><td>5.06</td><td>kostenlos</td></tr>
<tr><td>MSN Messenger</td><td>Microsoft</td><td>Jul.1999</td><td>Single Protocol</td> <td>W32</td><td>7.5</td><td>kostenlos</td></tr>
<tr><td>MSN Messenger</td><td>Microsoft</td><td>Jul.1999</td><td>Single Protocol</td> <td>W32</td><td>7.5</td><td>kostenlos</td></tr>
<tr><td>Google Talk</td><td>Google,Inc.</td><td> 24.08.2005</td><td>Single Protocol</td>W32</td><td> 1.0.0.72</td><td>kostenlos</td></tr>
<tr><td>Google Talk</td><td>Google,Inc.</td><td> 24.08.2005</td><td>Single Protocol</td><td>W32</td><td> 1.0.0.72</td><td>kostenlos</td></tr>
<tr><td>Trillian</td><td>Cerulean Studios</td><td>Jul.2000</td><td>Multi Protocol</td><td>W32</td><td>3.1</td><td>kostenlos</td></tr>
<tr><td>Trillian</td><td>Cerulean Studios</td><td>Jul.2000</td><td>Multi Protocol</td><td>W32</td><td>3.1</td><td>kostenlos</td></tr>
<tr><td>Gaim</td><td>Mark Spencer</td><td>Nov.1998</td><td>Multi Protocol</td><td>GTK</td><td>1.5.0</td><td> Lizenz kostenfrei</td> </tr>
<tr><td>Gaim</td><td>Mark Spencer</td><td>Nov.1998</td><td>Multi Protocol</td><td>GTK</td><td>1.5.0</td><td> Lizenz kostenfrei</td> </tr>
<tr><td>iChat</td><td>Apple Computer</td><td>Aug.2002</td><td> Multi Protocol</td><td>Cocoa</td></td> 3</td><td> kostenlos</td></tr>
<tr><td>iChat</td><td>Apple Computer</td><td>Aug.2002</td><td> Multi Protocol</td><td>Cocoa</td><td>3</td><td> kostenlos</td></tr>
<tr><td>Miranda IM</td>Miranda IM Project</td><td>2000</td><td> Multi Protocol</td><td> W32</td><td> 0.4.0.1</td><td> kostenlos</td></tr>
<tr><td>Miranda IM</td><td>Miranda IM Project</td><td>2000</td><td> Multi Protocol</td><td>W32</td><td>0.4.0.1</td><td> kostenlos</td></tr>
</table>
</table>



Revision as of 13:37, 13 January 2006


Instant Messaging ist eine internet basierte Protokoll-Anwendung, die es Benutzern ermöglicht, in Echtzeit miteinander zu kommunizieren

Was bedeutet Kommunikation bzw. Konversation?

Eine Konversation ist eine schnelle Übertragung von Informationen zwischen zwei oder mehr Parteien, die durch drei einfache Merkmale charakterisiert wird:

  1.Sie passiert spontan
  2.Sie dauert eine kurze Zeit an
  3.Sie ereignet sich zwischen Peers

Was sind Peers?

Peers sind sowohl Personen (P) als auch Anwendungen (A), die ihre Informationen wie eine Konversation austauschen. Somit kann eine Konversation zwischen:

       1. P-P: Email, chat und message boards
       2. A-A: Webdienste und IP routing
       3. P-A: intelligente Agentensysteme oder bots (zukünftige Möglichkeiten)

stattfinden.

Client/Server-Struktur des „Instant Messaging“

Die bekanntesten Instant Massaging-Anbieter, wie z.B. AIM (AOL), MSN (Microsoft), Yahoo! und ICQ, basieren alle auf einer Zentralen-Server-Struktur.

Bei einem zentralisierten Netzwerk, muss sich jeder Benutzer des Netzwerks mit dem zentralen Server verbinden. Dieser Server vermittelt zwischen allen Kommunikationen. Dementsprechend werden Kommunikations- und Userdaten auf diesem Server gespeichert.

Die Anmeldung vom Client an den Server erfolgt meistens durch das HTTP-Protokoll. Die Kommunikation zwischen zwei Clients kann ebenso per HTTP-Protokoll oder über andere Protokolle und Ports erreicht werden.

Diese Kommunikation zwischen zwei oder mehreren Clients ist unproblematisch, sofern sich die Clients im selben Netzwerk befinden, z.B. beide Clients sind mit dem AIM-Netzwerk verbunden. Problematisch wird es jedoch, falls Clients unterschiedlicher Netzwerke miteinander kommunizieren möchten, da die Server, der jeweiligen Netzwerke, nicht miteinander kompatibel sind.

Diese Inkompatibilität liegt an den unterschiedlichen Protokollen und deren Implementierungen. Um diesen Vorgang zu verstehen, werden wir zuerst ein paar Protokolle betrachten:

1.Internet Relay Chat (IRC) Protocol (RFC 1459)

Das IRC-Protokoll ist ein etabliertes, rein textbasiertes Chat-System, das jedoch durch weitere Kommandos über eine „Direct Client-to-Client-Verbindung“ (DCC) den Austausch von Daten und sonstigen Informationen erlaubt. IRC ermöglicht sowohl Gespräche zwischen 2 Teilnehmern (Privatchat) als auch Gesprächsrunden mit einer beliebigen Anzahl von Teilnehmern (Channels, Gesprächskanäle). Zur Vermittlung der Gespräche wird ein Netzwerk aus miteinander verbundenen Servern eingesetzt. Somit wird die Belastung auf viele Rechner verteilt und man kann eine beliebig große „Chatlandschaft“ ermöglichen. Die Kommunikation (ursprünglich: TCP/IP) zwischen Client/Server und Server/Server wird über Nachrichten (messages) in Befehlsform abgewickelt. Die maximale Länge einer Nachricht beträgt 510 Zeichen. Zudem besteht eine Nachricht aus dem Absender (prefix), dem Befehl (command) und zusätzlichen Befehlsparametern, wie z.B. Fehlerkorrektur. Anschließend kann der Server eine Antwort-Nachricht (reply) senden. Wobei sich die Reply-Nachricht gegenüber der obigen Erklärung für eine Nachricht(message) nur darin unterscheidet, dass anstelle des Befehls (command) ein Reply-Code (3-stellige Zahl mit fester definierter Bedeutung) generiert wird. Zudem ist der zwingende Bestandteil einer Nachricht nur die Angabe eines Befehls. Außerdem schicken die Clients Nachrichten ohne Absender, da diese vom Server ergänzt werden und somit Spoofing (Falschangaben) verhindert wird. Server routen oft die Nachrichten bloß durch und benötigen deshalb nur Ziel und Quelle einer Nachricht.

Vorteile:

1. Verglichen mit anderen Chat-Systemen sehr leistungsfähig und robust
2. Trotz enormer Ausmaße bewegt sich die Verzögerung bei der Vermittlung im Bereich von
   Sekunden und liegt deutlich darunter

Nachteil:

Durch unabhängige Weiterentwicklungen, im Bereich der Kommunikation zwischen Servern innerhalb 
eines IRC-Netzwerkes werden teilweise auch verkürzte Abwandlungen des Protokolls eingesetzt. 
Daraus folgt, dass keine einheitlichen Standards über die Erweiterungen existieren. Dies 
wiederum impliziert Inkompatibilität.

2.OSCAR-Protokoll (ICQ und AOL)

OSCAR steht für Open System for Communication in Realtime. Das Protokoll ist unveröffentlich (propietär) und beruht bisher auf Reverse Engineering. Das original ICQ-Protokoll gebrauchte eine Direktverbindung zwischen den Clients. OSCAR hingegen setzt auf Verbindungen über den Server ICQ kann auch in das IRC-Netzwerk gelangen, indem ICQ sich mit dem hauseigenen IrcQnet.icq.com-Server verbindet. Das OSCAR-Protokoll baut auf TCP auf und besteht selbst aus zwei Protokollschichten, nämlich das Flap- und SNAC-Paket. Das Flap besteht aus dem Flap-Header, Channel, Sequenznummer und der Größe der angehängten Daten. Der Channel ist ähnlich wie die Ports für TCP und UDP, steht allerdings für einen bestimmten Vorgang: z.B. SNAC-Paket, Neue Verbindung, Flap-Fehler und Keep-Alive. SNAC-Pakette sind in sogenannten Service Families organisiert. Jede Familie hat eine ID-Nummer und jeder darin enthaltene SNAC-Typ eine weitere "Unter-ID" (Subtype). Nach dem Login teilt der Server mit, welche SNAC Families er unterstützt, nur diese kann/soll der Client nutzen.


3. SIP-Protokoll (Beführworter: Microsoft)

SIP steht für Session Initiation Protocol und wird im RFC 3261 beschrieben. Dabei wurden auf folgende Dinge geachtet: leichte Implementierbarkeit, Skalierbarkeit, Erweiterbarkeit und Flexibilität. Das SIP-Protokoll kann beliebige Sessions mit einem oder mehreren Teilnehmern verwalten. Sessions können beliebige Multimediaströme, Konferenzen, Computerspiele usw. sein.

Zuletzt möchte ich noch die Entwicklung auf Client-Seite kurz erwähnen. Die Auswahl der Clients ist ziemlich groß und zudem auch kostenlos. Es gibt sowohl Singel- als auch Multi-Clients, wobei der Unterschied darin besteht, dass Singel-Clients sich nur mit einem Netzwerk verbinden können. Wohingegen Multi-Clients sich mit mehreren unterschiedlichen Netzwerken verbinden können, sofern der Client die Netzwerke unterstützt:

Generelle Informationen:

IM / GI EntwicklerErstes ReleaseTyp ToolkitAktuelle stabile Version Kosten
AOL IM AOL Mai 1997Single ProtocolW325.1 (Win), 4.3(Mac) kostenlos
Yahoo!MessengerYahoo! Jun.1999Single ProtocolW32,7.0 (Win, 2.5.3 (Mac)Cocoas,1.0.4-1 (Unix),4 FreeBSD, GTKkostenlos
ICQMiarbilisNov.1996Single ProtocolW325.06kostenlos
MSN MessengerMicrosoftJul.1999Single Protocol W327.5kostenlos
Google TalkGoogle,Inc. 24.08.2005Single ProtocolW32 1.0.0.72kostenlos
TrillianCerulean StudiosJul.2000Multi ProtocolW323.1kostenlos
GaimMark SpencerNov.1998Multi ProtocolGTK1.5.0 Lizenz kostenfrei
iChatApple ComputerAug.2002 Multi ProtocolCocoa3 kostenlos
Miranda IMMiranda IM Project2000 Multi ProtocolW320.4.0.1 kostenlos

Netzwerk-Unterstützung:

IM/Netzwerke AIM ICQ MSN Messneger Yahoo!Messenger IRC Jabber Bonjour NovellGroupWise AOL IM Ja Ja Nein Nein Nein Nein Nein Nein Yahoo!Messenger Nein Nein Nein Ja Nein Nein Nein Nein ICQ Ja Ja Nein Nein Nein Nein Nein Nein MSN Messenger Nein Nein Ja Nein Nein Nein Nein Nein Google Talk Nein Nein Nein Nein Nein Ja Nein Nein Trillian Ja Ja Ja Ja Nein Nein Nein Nein Gaim Ja Ja Nein Nein Nein Ja Ja Ja iChat Ja Ja Nein Nein Nein Ja Ja Ja Miranda IM Ja Ja Ja Ja Ja Ja Ja Ja


Ein weiteres Problem ist, dass die meisten Instant Messenger nicht plattformunabhängig sind und somit nicht für alle Systeme vorhanden sind. Dies ist in der folgenden Tabelle aufgeführt:

Betriebssysteme:

IM/Betruebssysteme Windows Mac OS X Unix, Linux, BSD AOL IM Ja Ja Ja Yahoo!Messenger Ja Ja Ja ICQ Ja Ja Ja MSN Messenger Ja Ja Nein Google Talk Ja(nux 2000/XP/2003) Nein(geplant) Nein Trillian Ja Nein Nein Gaim Ja Ja Ja iChat Nein Ja Nein Miranda IM Ja Nein Nein



Zusammenfassung

Es gibt keinen Instant Messenger, der: 1. zu allen Netzwerken eine Verbindung aufbaut 2. plattformunabhängig ist 3. alle wichtigen Funktionen implementiert hat Mit allen wichtigen Funktionen sind, z.B. Verschlüsselung, Dateitransfer, Audio Chat, Multi- Person Audio Chat, Video Chat, Multi-Person Video Chat, SMS, usw. gemeint.

Dies liegt aber an den Protokollen und deren unterschiedlichen Implementierung. Daraus folgt Inkompatibilität zwischen den Server und Clients.

Quellen:

• Andy Oram (2001). Peer-to-Peer: Harnessing the Power of Disruptive Technologies. O’Reily • Paper: Chapter 1 Introduction to Instant Messaging • Running-gag.de. OSCAR (Protokoll). Quelle: http://www.running-gag.de/wiki/OSCAR_%28Protokoll%29 • Ihse.net. The ICQ Protocol Site. Quelle: http://www.ihse.net/icq/ • Running-gag.de. Session Initiation Protocol. Quelle:

       http://www.running-gag.de/wiki/Session_Initiation_Protocol

• Wikipedia. Internet Relay Chat. Quelle: http://de.wikipedia.org/wiki/Internet_Relay_Chat • Wikipedia. Instant Messaging. Quelle: http://de.wikipedia.org/wiki/Instant_Messaging • Syndicon.de. Instant Messaging Glossar. Quelle:

       http://www.syndicon.de/im_hilfe/im_glossar/index.html.de.html