Mike's Protocol

Mike's Protocol

Das Gnutella2-Peer-to-Peer-Protokoll ist eine 2002 von Michael Stokes veröffentlichte Rundumerneuerung des Gnutella-Protokolls. Alles bis auf das alte Handshake des Gnutella-Protokolls wurde komplett neu erdacht. Somit ist neues System entstanden, welches über andere Paketformate, einen anderen Suchalgorithmus und ein stark verbessertes Metadatensystem verfügt. Gnutella2 hat zwischen 250.000 und 300.000 Nutzer je nach Tageszeit[1] und ist vor allem durch seinen meistgenutzten Client Shareaza bekannt.

Inhaltsverzeichnis

Geschichte

Im November 2002 gab Michael Stokes das Gnutella2-Protokoll im Gnutella Developers Forum (GDF) bekannt. Sofort darauf gab es einen langen Diskurs unter den Entwicklern. Einige vertraten die Meinung, dass das eigentliche Ziel von Gnutella2 sei, komplett mit dem alten Gnutella-0.6-Protokoll zu brechen und somit viele der Dinge, die als Behelfslösung vorhanden waren, nun endlich zu überwinden. Andere hingegen vertraten die Meinung (hauptsächlich Angehörige der LimeWire- und BearShare-Lager), dass diese nur ein Publicity-Gag sei und versagten jegliche technische Unterstützung. Diese Gruppe weigert teilweise bis heute das Netzwerk Gnutella2 zu nennen und spricht nur von „Mike's Protocol“. Ein weiteres Argument, das dies Gruppe gegen das Protokoll vorbringt, ist dass der Name (durch die angehängte 2) andeutet, das Protokoll sei eine Nachfolgerversion des älteren Gnutella-Protokolls, was durch seine Andersartigkeit nicht stimme.

Seltsamerweise benutzt das Gnutella2-Protokoll die alte „GNUTELLA CONNECT/0.6“-Handshake-Kennung zum Verbindungsaufbau. Dies ist die Kennung, wie sie in der Gnutella-0.6-Spezifikation dokumentiert ist. Auch hierüber existiert eine Meinungsverschiedenheit unter den Entwicklern. Während einige dies als Schritt sehen, um Rückwärtskompatibilität mit dem alten Protokoll zu halten, so dass Gnutella-Clients das neue Protokoll schrittweise in ihren Code integrieren können, kritisieren andere aus dem GDF dies als Versuch, auf Kosten des Gnutella-Netzwerkes einen neuen, völlig ohne Beziehung zum alten Netzwerk stehenden, Standard zu etablieren.

Nachdem die Entwickler auf ihren Standpunkt festgefahren waren, entstand ziemlich schnell ein Flamewar, hauptsächlich durch und um den führenden BearShare-Entwickler Vincent Falco, so dass die konträren Seiten noch weiter zementiert wurden.

Der Entwurf mit den Spezifikationen wurde am 26. März 2003 veröffentlicht, danach folgten noch ein paar genauere und konkretere Spezifikationen. Gnutella2 (G2) wird von den meisten „alten“ Gnutella-Clients nicht unterstützt. Im Gegensatz dazu gibt es eine große Unterstützung der neuen Gnutella2-Clients für das alte Gnutella-Netzwerk. Viele Gnutella2-Fürsprecher behaupten, dass dies aus politischen Gründen so sei, Gnutella(1)-Leute entgegnen dagegen, dass es technische Gründe dafür gebe.

Funktionsweise

Gnutella2 teilt die Nodes in zwei Gruppen ein. Blätter (engl. original leaves) und Hubs. Die Blätter halten nur ein oder zwei Verbindungen zu den Hubs aufrecht, während die Hubs Hunderte von Verbindungen zu den Blättern und anderen Hubs halten. Wenn nun eine Suchanfrage erfolgt, versucht – sofern noch nicht vorhanden – der Node zunächst einmal eine Liste von Hubs zu bekommen und kontaktiert dann die Hubs in dieser Liste. Dabei merkt er sich, welche Hubs schon besucht wurden. Dies wird solange fortgesetzt, bis die Liste abgearbeitet worden ist oder aber eine vordefinierte Suchschranke überschritten wurde. Somit wird sichergestellt, dass ein Benutzer eine weit verbreitete Datei einfach und ohne das Netz zu überlasten finden kann. Theoretisch wäre er sogar in der Lage eine einzelne (einmalige) Datei irgendwo im Netzwerk aufzuspüren.

Die Hubs führen einen Index und wissen so, welche Dateien jedes Blatt anbietet. Der Index, genannt Query Routing Table, ist ein Hash-Index der Suchbegriffe. Diese Liste der Suchbegriffe lädt das Blatt zum Hub hoch, der Hub generiert daraus eine kombinierte Version mit allen Schlüsselwortlisten der Blätter, die er betreut. Diese kombinierte Liste sendet er nun zu seinen Nachbar Hubs, um so die Anzahl der weitergeleiteten Suchanfragen zu reduzieren. Somit kann der Hub die benötigte Bandbreite reduzieren, da Suchanfragen nun nur noch an bestimmte Hubs oder Blätter weitergeleitet werden müssen.

Gnutella2 benutzt ausführlich das User Datagram Protocol (UDP), statt des Transmission Control Protocols (TCP), für seine Suchanfragenpakete. Der Datenoverhead, der durch TCP vorhanden wäre, würde ein Zufallsbewegungssuchsystem unmöglich machen, obwohl selbstverständlich auch UDP gewaltige Nachteile bietet.

Protokoll-Merkmale

Gnutella2 benutzt ein erweiterbares binär-XML-ähnliches Paketformat. Dieses ist als Antwort auf die vielen Behelfslösungen in Gnutella gedacht und soll ermöglichen, dass zukünftige Verbesserungen des Netzwerkes oder Erweiterungen von einzelnen Clients hinzugefügt werden können, ohne dass dadurch Funktionsstörungen in den anderen oder alten Clients entstehen. Viele Entwickler behaupten, dass es somit einfacher wäre, ein Gnutella2-Client zu entwickeln, als einen Gnutella-Client. Allerdings sehen andere Entwickler das Generic Gnutella Extension Protocol (GGEP) als schon vorhandene adäquate Lösung für das oben adressierte Problem an.

Gnutella2 setzt SHA1-Hashsummen zur Datei-Identifikation ein. Des weiteren kommen auch Tiger-Tree-Hashes zum Einsatz, so dass damit eine einzelne Datei zuverlässig parallel von mehreren Quellen (Multi-source-downloading/swarming) heruntergeladen werden kann. Auch wird so das zuverlässige Uploaden von Dateiteilen während des Dateiladens ermöglicht.

Um darüber hinaus ein robustes, vollständiges Suchsystem anbieten zu können, werden in Gnutella2 Metadaten zur verbesserten Benennung und Bewertung des Inhaltes eingesetzt. Damit können vielfältigere Qualitätsinformationen in den Suchergebnissen aufgeführt werden, als dies durch den bloßen Dateinamen möglich wäre. Nodes können diese Informationen sogar weitergeben, wenn sie die bewertete Datei nicht mehr besitzen. Somit können die Benutzer Viren oder Würmer markieren und diese Information den anderen Benutzern zur Verfügung stellen, ohne eine Kopie dieser Viren oder Würmer auf dem Computer behalten müssten.

Zusätzlich nutzt Gnutella2 Datenkompression, um so die für die Verbindungen benötigte Bandbreite zu reduzieren.

Clients

Einige der Gnutella2-Clients:

Siehe auch

Fußnoten und Referenzen

  1. Anzahl der Teilnehmer am G2-Netzwerk. Trillinux crawler (G2paranha). Abgerufen am 30. April 2009.
  2. Shareazas Anteil am Overlay-Netzwerk von G2. Trillinux crawler (G2paranha). Abgerufen am 18. September 2008.

Weblinks


Wikimedia Foundation.

Нужна курсовая?

Schlagen Sie auch in anderen Wörterbüchern nach:

  • Mike Campbell (Pvt) Ltd and Others v Republic of Zimbabwe — Court SADC Tribunal Full case name Mike Campbell (Pvt) Ltd and 78 Others versus the Republic of Zimbabwe Date decided 28 November 2008 Citation(s) [ …   Wikipedia

  • Protocol (band) — Infobox musical artist Name = Protocol http://img301.imageshack.us/img301/1617/protocolmmmcm7.jpg] Img capt = Img size = Landscape = Background = group or band Alias = Origin = United Kingdom Genre = Pop Years active = 2005 present Label =… …   Wikipedia

  • Mike Hulme — For the swimmer, see Michael Hulme. Mike Hulme Born July 23, 1960 (1960 07 23) (age 51) London Residence Norwich Nationality British Occupation …   Wikipedia

  • Mike Peden — is a British producer/remixer/composer best known for his work with the Lighthouse Family. He was the producer of the 2004 album Free Me, the second album by former Spice Girl Emma Bunton. He co wrote the song You and I for Will Young. With his… …   Wikipedia

  • Political positions of Mike Gravel — Mike Gravel is a former United States Senator who previously sought nomination from the Democratic Party and Libertarian Party for the office of President of the United States of America during the United States presidential election of 2008.… …   Wikipedia

  • Alpha Protocol — Entwickler …   Deutsch Wikipedia

  • Kyoto Protocol — Participation in the Kyoto Protocol, as of December 2010, Green = Countries that have signed and ratified the treaty              (Annex I II countries in dark green) Grey =… …   Wikipedia

  • Network Voice Protocol — NVP redirects here. For other uses, see NVP (disambiguation). The Network Voice Protocol (NVP) was a pioneering computer network protocol for transporting human speech over packetized communications networks. It was an early example of Voice over …   Wikipedia

  • Microcom Networking Protocol — Telephone network modem standards ITU V Series | V.92 | K56flex | X2 | MNP | Hayes command set The MNP (Microcom Networking Protocol) family of error correcting protocols were commonly used on early high speed (2400 bit/s and higher) modems.… …   Wikipedia

  • Unix to unix copy protocol — Pile de protocoles 7 • Application 6 • Présentation 5 • Session 4 • …   Wikipédia en Français

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”