- BitTorent
-
BitTorrent (protocole)
Pour les articles homonymes, voir BitTorrent.BitTorrent est un protocole de transfert de données Pair à pair (P2P) à travers un réseau informatique. Le protocole a été conçu en avril 2001 et mis en place à l'été 2002 par le programmeur Bram Cohen, et est dorénavant maintenu par la société BitTorrent Inc..
L'échange de fichiers BitTorrent représenterait entre 27 et 55 % de la bande passante totale d'internet[1].
Le protocole BitTorrent part du constat suivant :
- Quand une information se trouve sur un serveur informatique unique, plus elle est demandée, moins elle est accessible (par saturation du serveur).
- Cette tendance est renversée si chaque client informatique ayant téléchargé l'information devient aussitôt serveur à son tour.
- Une façon de procéder est de découper l'information à partager en segments, et de distribuer des segments différents à des interlocuteurs différents afin qu'ils aient eux-mêmes quelque chose à échanger.
Sommaire
Avantages
BitTorrent est une méthode pour distribuer largement de grandes quantités de données en répartissant la charge inhérente en matière de matériel, hébergement Internet et bande passante quand, dans le modèle classique, elle incombe au seul distributeur originel. Ce dernier n'a plus à servir chaque destinataire : les clients eux-mêmes servent les données déjà reçues aux nouveaux destinataires. Le coût et la charge de la distribution des données sont donc considérablement réduits ; le protocole procure en même temps une redondance contre les problèmes matériels et réduit la dépendance à l'égard du distributeur originel.
L'apparition de BitTorrent a par exemple permis la mise à disposition de distributions Linux complètes sur DVD, y compris pour des versions alpha et bêta en lieu et place des téléchargements de simples CDs.
Les techniques utilisées sont : le téléchargement poste à poste depuis différents « pairs » (peer) pour un même fichier (technique dite multisourcing) et le morcellement du fichier en blocs qui le permet. Les blocs peuvent arriver dans un ordre quelconque depuis des sources multiples, le fichier étant réputé téléchargé lorsque la totalité des blocs sera parvenue, quel que soit l'ordre d'arrivée de ceux-ci ou leurs provenances - qui n'ont de fait aucune importance[2].
La validité des données est implicitement garantie : si le fichier est corrompu, c'est qu'il l'était à l'origine, ou qu'il l'a été sur l'ordinateur le téléchargeant (mémoire vive défectueuse, par exemple, mais en aucun cas durant le transfert de données). Les blocs corrompus sont invariablement rejetés.
L'efficacité du réseau est maximale lorsqu'il y a beaucoup d'utilisateurs, car tous ceux qui téléchargent partagent par construction ce qu'ils téléchargent. Il n'y a pas à attendre dans une file virtuelle pour commencer : tout est immédiat dès lors, cela va de soi, qu'au moins une personne partage le fichier désiré.
Par rapport à d'autres systèmes P2P, ce système a l'avantage de créer une sorte de cercle vertueux lors du partage des fichiers. En effet, dès que des parties du fichier souhaité sont téléchargées, elles sont disponibles pour les autres utilisateurs. De plus un système de « récompense » permet de recevoir plus si l'on donne plus. Celui qui donne peu ou pas du tout recevra beaucoup moins d'autrui.
Il tire fortement parti de l'accroissement de la bande passante disponible en upload, c'est-à-dire en envoi de données, des connexions réseau.
Inconvénients
Pour ceux dont la connexion au Web est calculée et facturée au volume de données, la consommation (upload et download) peut dans certains cas doubler ou tripler.
La bande passante en upload peut être saturée si le logiciel utilisé pour télécharger sur le réseau BitTorrent n'est pas configuré correctement (en fonction des capacités de la connexion à Internet de l'utilisateur) et qu'aucune qualité de service appropriée n'est appliquée à la connexion : cela entraîne un ralentissement important de toutes les connexions à Internet en cours. Les téléchargements HTTP et FTP peuvent quasiment s'arrêter et la lecture de radios/tv Internet peut être saccadée voire impossible. Les logiciels de messagerie instantanée (live messenger, pidgin, irc...) ne sont pas affectés en raison du faible volume de données qu'ils ont besoin de transmettre vers et depuis Internet.
Pour éviter la saturation de la bande passante ascendante, il est recommandé de configurer le client de façon à ce qu'il n'utilise que 80 % de celle-ci. Exemples :
- 6 Ko/s maximum pour une connexion 56 K (bande passante en upload : 8 Ko/s) ;
- 12 Ko/s maximum pour une connexion RNIS 128 kb/s symétrique ou ADSL xxx/128 (bande passante 16 Ko/s) ;
- 51 Ko/s maximum pour une connexion ADSL xxxx/512 (bande passante 64 Ko/s) ;
- 102 Ko/s maximum pour une connexion ADSL xxxxx/1024 (bande passante 128 Ko/s).
Une personne qui partage peu recevra aussi beaucoup moins des autres utilisateurs. Il existe cependant des clients basés sur le moteur BitComet ne respectant pas totalement le protocole BitTorrent ; ces clients permettent de recevoir beaucoup de données tout en partageant peu (en faisant croire aux autres peers qu'ils ont déjà envoyé des données). Du fait de leur non-respect du protocole, ces clients ralentissent potentiellement le réseau BitTorrent.
Nouveaux venus
Le protocole BitTorrent exploite le principe « un prêté pour un rendu », favorisant l'échange de données entre des machines qui ont déjà coopéré dans le passé. Ceci peut entraîner un démarrage difficile d'un nouveau venu lorsque toutes les autres machines ont déjà presque la totalité du fichier.
Disponibilité
Le mode de fonctionnement observé de BitTorrent souffre d'un handicap majeur : au début de la mise en disponibilité d'un fichier, beaucoup de sources sont disponibles pour le télécharger, surtout s'il est populaire ou attendu depuis longtemps ; mais avec le temps, il devient de moins en moins partagé, et donc de moins en moins disponible au téléchargement, ce qui aboutit à la « mort » du torrent. Ainsi, il est rare qu'un torrent soit actif pendant plus de quelques mois, voire quelques semaines ou même quelques jours.
Pour remédier à cela, les clients proposent maintenant de laisser le torrent « ouvert », une fois téléchargé. Cela devient alors une source pure et remédie à cet inconvénient.
Une limite à ce raisonnement est la place disponible sur les disques durs et autres systèmes de stockage en ligne. En règle générale, on est « bon citoyen »[réf. nécessaire] quand on laisse le fichier en partage assez longtemps pour qu'il soit lui-même au moins autant téléchargé (taux de partage de 1 ou plus) ; dans le cas contraire, on est considéré comme une sangsue (leecher).
En bref pour que le système fonctionne bien il faut au minimum envoyer autant que ce que l'on a téléchargé. Ex: si on télécharge un fichier de 700Mo, il faudra envoyer (aux autres utilisateurs) 700Mo minimum pour éviter que le torrent "meurt".
Utilisation
Il faut souvent utiliser un logiciel dédié pour télécharger les fichiers alors qu'un fichier accessible sur un site web ne nécessite rien de plus que le navigateur pour le rapatrier.
Note : Le navigateur web Opera 9 inclut un client BitTorrent, les fichiers torrent étant traités de façon transparente. Certains plugins du navigateur Mozilla Firefox permettent également d'ajouter cette fonctionnalité au navigateur. Tout comme la version 1.80 du téléchargeur Flashget qui prend aussi en charge ce type de fichier. Aussi, de nombreux logiciels p2p (Shareaza, LimeWire...) contiennent cette fonction.
La première configuration peut être fastidieuse, si l'on ne possède pas quelques notions minimales de réseau informatique, adresse IP, pare-feu (firewall) et notion de port logiciel, par exemple. La plupart des logiciels clients récents permettent une configuration automatique en fonction des caractéristiques du réseau environnant, mais certains clients/modems requièrent une configuration spécifique. Par exemple, pour télécharger à une vitesse optimale en utilisant une Box, il faut en général rediriger manuellement (dans la configuration du mode routeur de la "Box") le port utilisé par le client BitTorrent vers l'IP (sur le réseau local) de l'ordinateur sur lequel tourne le client. Dans le cas d'un client utilisant un port au hasard dans une plage prédéfinie (comme BitTornado qui utilise par défaut un port au hasard parmi les ports 10 000 à 60 000), il faut rediriger la plage entière vers l'ordinateur faisant tourner le client. Cela peut poser problème lorsqu'un autre ordinateur sur le même réseau local utilise un port compris dans cette plage.
Le protocole marque aussi récemment sa flexibilité et son potentiel en se développant sur des supports inattendus tel que la PSP ou encore en améliorant ses performances avec des plugin tel que Ono.
Vocabulaire
Availability / disponibilité : (aussi appelé « distributed copies ») La quantité de copies complètes du fichier disponibles. Un peer qui se connecte avec une fraction de fichier ajoute cette fraction à la disponibilité (si aucun autre ne possède déjà cette partie du fichier). Chaque seed ajoute 1,0 à ce nombre, étant donné qu'il possède la totalité du fichier. Ainsi, un peer avec 65,3 % d'un fichier téléchargé augmente la disponibilité de 0,653. Si deux peers ont téléchargé chacun la même moitié d'un fichier et qu'ils sont rejoints par un seeder (semeur), la disponibilité s'élève à 1,5.
Leecher : Une « sangsue » (leech en anglais) est un client souhaitant télécharger le fichier, mais ne le possédant pas en totalité. Ce terme a également un sens péjoratif pour qualifier ceux qui téléchargent sans envoyer en contrepartie de fichier sur le réseau. Lors de la première apparition d'un torrent, il n'y a que peu de sources (seeds) et beaucoup de sangsues (leech).
Peers : Clients pouvant transmettre une partie de l'archive. (Il ne possède pas l'intégralité de celle-ci).
Scrape : Le client Bittorrent (voir clients utilisant le réseau BitTorrent) débute par un scrape, ce qui consiste à demander au tracker des informations sur le nombre total de sources (seeds) et de sangsues (leech). Ce nombre sera généralement affiché entre parenthèses.
Seed : Une semence (seed en anglais) est un client partageant un fichier complet.
Share Ratio : Proportion entre le nombre de données envoyées, partagées (upload) et le nombre de données reçues (download). Dans un monde utopique, tout un chacun utilisant ce service devrait avoir un ratio de 1:1, ce qui indique qu'il y a eu autant de données envoyées que reçues. De cette façon les téléchargements sont rapides et efficaces pour tous.
Superseed : Seed qui tente de minimiser la quantité de données qu'il envoie jusqu'à ce qu'un leecher obtienne la totalité des fichiers du torrent et devienne ainsi un seeder supplémentaire. Cette fonction ne devrait être utilisée que lorsque qu'il n'y a qu'un seul seeder, ou très peu d'entre eux, disponibles pour un torrent, et que ces seeders disposent de capacités d'upload relativement limitées. L'opération consiste à ne déclarer posséder aucune partie de l'archive. Lorsque les clients se connectent, le super-seeder les informe qu'il dispose d'une nouvelle partie que personne ne possède. Il transmet la partie en question et ne transmettra aucune nouvelle partie de l'archive tant qu'il n'aura pas reçu confirmation que la pièce a été transmise à nouveau. De cette manière, les clients en mode superseed n'envoient que les morceaux qui n'ont encore jamais été envoyés, et s'assurent de leur bonne diffusion par, et parmi, les leechers.
Swarm : Tous les peers (y compris les seeds) qui partagent un même torrent sont appelés un essaim. Par exemple, six peers et deux seeds forment un essaim de huit unités.
Torrent : Selon le contexte, un torrent peut signifier soit un fichier de métadonnées .torrent, soit tout fichier décrit par lui. Le fichier torrent contient des métadonnées relatives aux fichiers qu'il rend téléchargeables, y compris leurs noms, tailles et sommes de contrôle de toutes pièces du torrent. Il contient également l'adresse IP d'un tracker qui coordonne la communication entre les peers du swarm (essaim).
Tracker : Un traqueur est un serveur qui sait en permanence quels seeds et quels peers se trouvent dans le swarm (l'essaim). Les clients lui envoient régulièrement des informations. En échange, ils reçoivent des informations sur d'autres clients auxquels ils peuvent se connecter. Le traqueur n'est pas directement impliqué dans le transfert de données et ne possède pas de copie du fichier. Les quelques secondes par heure où un client se connecte au traqueur sont en principe les seules où il puisse se faire identifier (mais par quelques dizaines d'autres clients seulement).
Web Seeding : Utiliser un serveur web comme seed. À l'aide de scripts php, d'une modification du torrent on peut permettre à un serveur web de seeder un torrent. Cette fonctionnalité a été intégrée dans les clients Mainline, Azureus, et Bit-tornado.
Copyright
Bien que le protocole BitTorrent ait été open source jusqu'à la sortie de la version 6 du client officiel, il subsiste des problèmes liés au copyright. Certains organismes de surveillance des droits d'auteur s'intéressent de près aux sites fournissant les trackers car ceux-ci sont souvent des moyens de distribution de fichiers sous copyright (musiques, films, etc).
La Motion Pictures Agency of America (MPAA) en particulier, a intenté de multiples procès envers divers sites référençant des fichiers
.torrent
en raison du grand nombre de fichiers illégalement distribués ainsi. Une des plus récentes affaires concerne le site ThePirateBay.org, poursuivi par la police suédoise et le MPAA (début de l'affaire 31 mai 2006 ; verdict de première instance au 17 avril 2009: administrateurs et financier du site coupables, 1 an de prison ferme et 30 millions de couronnes suédoises, soit 2,7 millions d'euros de dommages et intérêt -- les condamnés font appel).Télécharger un fichier vidéo, image ou audio sous une licence propriétaire est un délit et plus encore, le distribuer à grande échelle pourrait être passible d'amendes (voir DADVSI). Mais les fichiers .torrent ne sont pas à proprement parler ces fichiers sous copyright, ils ne sont qu'un moyen de les télécharger. Ainsi, en principe, les sites rassemblant des trackers ne sont pas "hors-la-loi".
La légalité de la détention de fichiers
.torrent
permettant le téléchargement de fichiers sous copyright reste encore assez floue, le MPAA et les autres organismes de protection de droits d'auteur ayant attaqué en justice des sites aussi divers que des hébergeurs de fichiers ou des moteurs de recherches pour torrents n'en hébergeant pas (TorrentSpy 27 février 2006).La législation dépend du pays où l'on se trouve, par exemple :
- en Suisse, il est illégal de mettre à disposition un contenu sans l'accord de l'ayant droit, mais pas de le télécharger (un usager ne peut en effet pas savoir si un contenu est licite avant de le connaître).
- en France, mise à disposition et téléchargement sont illégaux sauf accord de l'ayant droit, mais la charge de la preuve est tout sauf évidente : le nom d'un fichier et sa taille ne prouvent juridiquement rien sur le contenu de celui-ci.
BitTorrent 6 est associé à un changement majeur de licence : jusque là, le programme et le protocole associés étaient open source. La licence d'utilisation a été modifiée[réf. nécessaire], et le protocole ne verra plus son code publié, bien qu'il soit possible d'obtenir un SDK afin de continuer le développement de logiciels tiers.
Liste des clients les plus populaires
De nombreux programmes alternatifs ont pu être développés. Parmi les plus populaires, on peut citer :
- ABC, sous Linux et Windows
- Azureus développé en Java (Vuze), sous Linux, Mac OS X et Windows
- BitComet, Windows
- BitSpirit, client pour Windows
- BitTornado, sous Linux et Windows
- Bits on Wheel pour Mac OS X.
- BitTorrent : client minimal (officiel), pour les environnements GNU/Linux, Mac OS X ou Windows
- Creatorrent client ultraléger pour créer un torrent en mode console, Linux
- Deluge, client BitTorrent crypté sous GNU/Linux, Mac OS X et Windows
- FlashGet, Gestionnaire de téléchargement gérant aussi les Torrents Windows
- FrostWire, Windows, Linux, Mac OS X
- KTorrent, client pour l’environnement KDE, GNU/Linux
- LimeWire, Windows, Linux, Mac OS X
- MLDonkey, client multi-protocole, sous Linux, Mac OS X et Windows
- MonoTorrent, client ultraléger et multiplate-forme (mono)
- µTorrent (microtorrent), client ultraléger, sous Mac OS X et Windows
- Opera (suite internet) depuis sa version 9 pour Mac OS X, GNU/Linux et Windows
- rtorrent, client ultraléger mais tout à fait complet, en mode console sous Unix
- Shareaza, sous Windows
- Transmission pour GNU/Linux, Mac OS X et BeOS
- Xtorrent pour Mac OS X.
- Xunlei, Gestionnaire de téléchargement chinois gérant aussi les Torrents, sous Windows
Le client officiel, rapidement concurrencé par les logiciels ci-dessus, porte le même nom que le protocole lui-même, BitTorrent.
Début décembre 2006, BitTorrent, Inc., la société créée par Bram Cohen, l’inventeur du BitTorrent, et Ashwin Navin, ancien de Yahoo!, annonce l’acquisition du logiciel propriétaire µTorrent.
BitTorrent Entertainment Network
BitTorrent ouvre le 26 février 2007 une plate-forme de téléchargement payante : BitTorrent Entertainment Network[3]. Si les prix pratiqués sont relativement peu élevés (3,99 $ pour un film récent) par rapport à d'autres plate-formes de ce type, BitTorrent Entertainment Network souffre en revanche du fait de proposer ses films uniquement pour la location, et protégés par des DRM[4]. Les studios ayant signé un accord de diffusion sont pour l'instant :
Sources
Voir aussi
Articles connexes
- P2P
- eXeem, autre logiciel utilisant les fichiers Torrent
- metalink, standard convenant aussi à BitTorrent
- Mininova, site permettant l'échange de fichiers torrents.
- The Pirate Bay, site permettant l'échange de fichiers torrents.
Liens externes
- (en) Site officiel
- (en) Catégorie BitTorrent de l’annuaire dmoz
- (en) Comparaison des logiciels BitTorrent
- (en) Spécification officielle du protocole
- Portail de l’informatique
Catégorie : Partage de fichiers
Wikimedia Foundation. 2010.