Soulseek

Soulseek ist eine Internettauschbörse, die von Nir Arbel, einem früheren Napster-Programmierer, geschaffen wurde. Wie bei Napster setzt das Netzwerk auf einen zentralen Server, der alle Clients bedient. Der einzige Server, der online ist, wird von Nir selbst betrieben. Dieser kann Schätzungen zufolge bis zu 100.000 Benutzer bedienen.
Grundlegende Möglichkeiten von SoulSeek sind:
- Suche nach Dateien
- Privater und öffentlicher Chat
- Things I Like: Suche nach Interpreten und Benutzern nach eigenem Geschmack
- Download und Upload von Dateien
Nutzern, die über PayPal Geld spenden, werden (je nach Höhe der Spende) zeitlich begrenzte Privilegien gewährt, die in der bevorzugten Behandlung innerhalb des Netzwerks bestehen.
Entwicklungsgeschichte
Bei SoulSeek steht der Community-Gedanke im Vordergrund. Das Programm wurde zuerst im Frühjahr 2001 auf einer IDM-Mailingliste vorgestellt, und von Beginn an waren etliche Musikproduzenten unter den Benutzern. Dies führte 2002 zur Gründung des Netlabels Soulseek Records, das Musik von Soulseek-Mitgliedern veröffentlicht. Im Mai 2004 und im November 2004 fanden in Augsburg (im Rahmen des Kulturfestivals Lab30) zwei "Soulseek-Festivals" statt, bei denen viele - teilweise aus Übersee angereiste - Soulseek-Künstler auftraten.
Technische Details
Netzwerktopologie
Das SoulSeek-Netzwerk besitzt eine Sterntopologie nach dem Client-Server-Prinzip ähnlich wie OpenNap. Allerdings ist es nicht möglich, mehrere Server miteinander zu verbinden (wie es bei OpenNap zum Beispiel der Fall ist). Grundsätzlich wird jede Kommunikation zwischen den Clients über den Server eingeleitet.
Der Server indiziert die freigegebenen Dateien der Clients nicht und ist somit nicht in der Lage, Suchanfragen direkt zu beantwortet. Sie werden stattdessen an die Clients weitergeleitet. Da im Laufe der Zeit der Server nicht mehr in der Lage war, den großen Ansturm an Benutzern zu bedienen, wurden sogenannte Parent-Nodes eingeführt. Das sind Clients mit hoher Bandbreite, deren Aufgabe darin besteht, die Suchanfragen (die sie vom Server geliefert bekommen) zu mehreren Kindkonten weiterzuleiten. Die Clients, die Suchanfragen erhalten, beantworten diese und senden die Treffer direkt per TCP an die suchenden Clients. Die Teilnehmer am Netzwerk sind somit keine reinen Clients im klassischen Sinne (wie zum Beispiel bei FTP), sondern übernehmen Aufgaben eines Servers.
Dateiaustausch
Es gibt Anzeichen dafür, dass möglicherweise privilegierte Benutzer (Benutzer, die eine Spende getätigt haben) bessere Suchergebnisse erhalten (s. SoulSeek Forum - Untersuchung). Die konkreteste bekannte Stellungnahme von offizieller Seite ist unter SoulSeek Forum - Statement von Nir Arbel zu finden.
Ist eine Datei mittels einer Suche gefunden, wird der Server zum weiteren Download nicht mehr benötigt. Es wird direkt eine TCP-Verbindung zum anbietenden Benutzer aufgenommen. Multi-Source-Downloads sind mit dem originalen Windows Clientprogramm nicht möglich und laut Nir Arbel auch explizit nicht geplant, da befürchtet wird, dass damit der Community-Gedanke des Netzwerks verloren geht. Aus technischer Sicht ist der Download einer Datei von mehreren Quellen aber durchaus möglich.
SoulSeek kennt keine Hash-Werte für Dateien, vermutlich wegen der Philosophie, eine Datei immer nur von einem einzigen Benutzer herunterzuladen, wodurch die Fehleranfälligkeit stark reduziert wird.
Protokoll
Die Kommunikation zwischen Server und Client bzw. zwischen Client und Client setzt auf TCP/IP auf und wird über Befehle abgewickelt, die aus einem binären Kopf und einem binären Rumpf bestehen. Der Kopf beinhaltet zwei vorzeichenlose, ganzzahlige 32-bit Werte im Little-Endian-Format. Der erste Wert spezifiziert die Länge des gesamten Befehls ausschließlich sich selbst und der zweite die Art des Befehls. Der Rumpf enthält Argumente in einem speziellen binären Format, wobei im wesentlichen nur die drei Typen Zeichenkette, ganze Zahl und Byte auftreten.
Kopf | Rumpf | ||||
Länge | ID | Zeichenkette | ganze Zahl | Byte | |
32-bit | 32-bit | 32-bit: Länge | Daten entsprechend der Länge | 32-bit | 8-bit |
Die Argumente des Rumpfes werden abhängig von der Art des Befehls interpretiert. Obige Skizze zeigt beispielhaft die drei verschiedenen möglichen Argumente.
Weblinks
- http://www.slsknet.org/ Offizielle SoulSeek-Seite mit Client für Windows
- http://soulseekportal.de/ Soulseekportal.de
- http://solarseek.sourceforge.net/ - Open Source Client für Mac OS X
- http://chris.schleifer.net/ssX ssX - Client für Mac OS X
- http://nicotine.thegraveyard.org/ Nicotine - Client für Linux, entstanden aus PySoulseek
- http://museek.thegraveyard.org/ Museek - Weiterer Client für Linux vom Entwickler von Nicotine
- soulseekrecords.com, soulseekrecords.net Soulseek Records
- Wikipedia:WikiReader/p2p-filesharing