MLDonkey est un client P2P multiplate-forme, pour les réseaux eDonkey, BitTorrent mais aussi FTP, les téléchargement direct et bien d'autres encore.
Il ne nécessite pas d'interface graphique pour continuer à télécharger. Accessible par interface web ou interfaces graphiques dédiées, MLDonkey est idéal à placer sur un serveur commandé à distance.
Installez le paquet mldonkey-server
Lors de l'installation une question vous sera posée: Faut-il lancer MLDonkey au démarrage du système?
Si vous découvrez MLDonkey, il est préférable de laisser décocher l'option. Vous pourrez l'activer plus tard lorsque vous aurez connaissances des différentes manière de l'utiliser.
Nous venons d'installer MLDonkey. Vous ne trouverez pas d'entrée dans le menu applications concernant MLDonkey puisque c'est un démon. Ensuite vous utiliserez un client graphique qui permettra de contrôler ce démon.
Pour démarrer ou arrêter MLDonkey copiez dans un terminal :
Pour le démarrer :
mlnet
Pour le stopper :
sudo killall mlnet
Démarrer MLDonkey à l'ouverture de la session :
Ajouter la commande mlnet sur le gestionnaire d'applications au démarrage.
Avec ce mode, même si vous changez ou quittez la session de l'ordinateur sur lequel est en fonction le démon, MLDonkey continuera d'être actif.
Pour le démarrer :
sudo /etc/init.d/mldonkey-server start
Pour le stopper :
sudo /etc/init.d/mldonkey-server stop
Activer le démon MLDonkey au démarrage de l'ordinateur (ce qui est proposé à l'installation) :
Il vous faut éditer le fichier /etc/default/mldonkey-server
et mettre le paramètre LAUNCH_AT_STARTUP à true.
Comme tout bon logiciel de P2P, MLDonkey a besoin de deux répertoires pour fonctionner :
Par défaut ces deux répertoires se situent dans /var/lib/mldonkey
, ce qui n'est pas très pratique. Nous allons donc modifier le démon afin qu'il place ces répertoires dans votre dossier personnel.
Avant de toucher au fichier de configuration du démon nous devons éteindre celui ci :
sudo /etc/init.d/mldonkey-server stop
Maintenant nous allons éditer le fichier /var/lib/mldonkey/downloads.ini
Il faut trouver la ligne contenant les paramètres incoming_directory et temp_directory, puis les remplacer par les répertoires de votre choix :
Ce qui donne par exemple :
temp_directory = "/home/mondossierpersonnel/.mldonkey/temp" (* The directory where downloaded files should be moved after commit *) incoming_directory = "/home/mondossierpersonnel/.mldonkey/fini"
Bien sûr nous devons créer ces deux répertoires.
Sous Feisty (en mode utilisateur)
Les dossiers se trouve dans /home/mondossierpersonnel/.mldonkey
, le fichier à éditer est alors /home/mondossierpersonnel/.mldonkey/downloads.ini
Trouvez la section pour les fichiers temporaires :
temp_directory = "/home/mondossierpersonnel/.mldonkey/temp"
Puis la section pour les répertoires de partage et de classement :
shared_directories = [ { dirname = "/home/mondossierpersonnel/.mldonkey/shared" (* dossier partagé*) strategy = only_directory priority = 0 }; { dirname = shared strategy = all_files priority = 0 }; { dirname = "/home/mondossierpersonnel/.mldonkey/incoming" (* dossier fichiers finis edonkey*) strategy = incoming_files priority = 0 }; { dirname = "/home/mondossierpersonnel/.mldonkey/incoming" (* dossier fichiers finis bittorrent*) strategy = incoming_directories priority = 0 };]
Pour des raisons de sécurité, le démon mldonkey est lancé par l'utilisateur mldonkey
appartenant au groupe mldonkey
.
Pour que ce dernier puisse aller écrire dans nos deux répertoires fraîchement crées, il faut modifier les droits :
On attribue les dossiers de mldonkey au groupe mldonkey
:
sudo chgrp -R mldonkey /home/mondossierpersonnel/.mldonkey/*
Enfin on autorise seulement les utilsateurs du groupe mldonkey à lire et modifier ces répertoires :
sudo chmod 660 -R /home/mondossierpersonnel/.mldonkey/*
Comme l'utilisateur mldonkey
, appartient également au groupe mldonkey
et que le démon est lancé par l'utilisateur mldonkey
, ce dernier pourra donc lire et écrire dans les répertoires définis.
Sous Feisty (en mode utilisateur) cette étape n'est plus obligatoire.
Une commande se révèle utile pour vérifier le bon positionnement des droits: sudo -u mldonkey /usr/bin/mlnet.
Un message d'erreur explicite “check rights” apparaît si les droits ne permettent pas à mldonkey d'écrire dans son répertoire.
Lorsque MLDonkey ne démarre plus et qu'il n'y a rien dans le log, il faut modifier le script de démarrage /etc/init.d/mldonkey-server
pour afficher des informations supplémentaires. Pour cela, chercher les lignes :
start-stop-daemon --start $WRAPPER_OPTIONS \ --pidfile $PIDFILE --background --exec $EXEC \ -- -log_file $SERVERLOG -pid $PIDDIR 2>&1
et remplacer –background
par –verbose
.
Au démarrage du service (service mldonkey-server start
), des infos seront affichées, et probablement la cause du problème. Ensuite, rétablir la ligne modifiée.
NB : ces lignes peuvent varier suivant les versions. Version pour cet exemple : 3.0.1.
Comme je l'ai dit, MLDonkey n'est que le cœur du système de téléchargement. Pour pouvoir le piloter facilement il vous faut un client graphique qui se connectera au démon et lui enverra des commandes.
L'avantage est que vous pouvez fermer le client graphique, le démon lui, continue à télécharger.
Un autre avantage est que vous pouvez configurer un PC dédié uniquement au téléchargement sur lequel tourne le démon, et piloter le téléchargement depuis un autre PC, ou même du bureau. Donc en résumé par exemple, un PC dans le salon qui fait du bruit et qui télécharge, un pc dans la chambre depuis lequel on lance les téléchargements et qu'on peut éteindre la nuit.
Par défaut vous utilisez MLDonkey en tant qu'utilisateur admin.
Si vous voulez l'utilisez à l'extérieur, vous pouvez facilement définir un reverse proxy dans apache qui pointera par exemple sur le dossier http://monsite/mldonkey. Comme ça, depuis internet, vous pouvez lancer des téléchargements.
MLDonkey fourni nativement une interface web pour piloter le démon. Elle est accessible par défaut sur le port 4080 (vous pouvez le changer dans la configuration de MLDonkey) de la machine qui héberge le démon (vous pouvez donc accéder à votre interface web à l'adresse http://localhost:4080/). Cette interface est en anglais uniquement.
Le premier client graphique que je vous présente est le plus simple à installer.
Il suffit d'installer le paquet mldonkey-gui
Puis le démarrer soit:
mlgui
Voir la page dédiée : KMLDonkey
Il existe plusieurs interfaces graphiques, ma préférée est Sancho : http://sancho.awardspace.com
C'est une interface gtk2 avec une icône dans le systray.
Récupérez l'archive de Sancho sur le site du projet, onglet Linux. Quand au choix de la version:
Nous supposerons que l'archive est téléchargée dans votre dossier personnel.
Créez le répertoire d'installation :
sudo mkdir /usr/local/sancho
Maintenant exécutons le script d'installation (À adapter en fonction de la version obtenu) :
sudo sh ~/sancho-0.9.4-59-linux-gtk.sh
Le script vous demande où le logiciel doit être installé :
Extract to directory [<sancho-0.9.4-59-linux-gtk>]:
Taper donc /usr/local/sancho
Sancho est installé. Vous pouvez Créez un raccourci en utilisant « sancho
» comme commande.
Les fichiers de configuration de Sancho dans votre dossier personnel appartiennent à root (car vous avez lancé l'installation en tant qu'administrateur). Nous allons donc remettre le bon propriétaire (vous !) à ces fichiers :
sudo chown -R $USER:$USER ~/.sancho
(vous pouvez remplacer $USER par votre login bien sûr
Vous pouvez maintenant démarrer sancho depuis le menu applications ⇒ internet.
Démarrez Sancho, allez dans Tools ⇒ Preferences. Dans la section sancho:main, dans l'onglet General, là où il y a écrit « Locale specific sancho*.properties file », choisissez fr_FR dans le menu déroulant puis redémarrez l'application.
La dernière étape est de se connecter à un serveur pour pouvoir lancer une recherche.
Cliquez sur l'onglet serveur.
En haut a droite cliquez sur la planète avec une croix verte intitulé “ajouter un fichier serveur.met” entrez-y l'adresse d'un fichier de serveur .met que vous récupérerez sur des sites comme http://ed2k.2x4u.de
Il devrait aussi récupérer une liste d'autre serveurs.
Une fois connecté lancez une recherche.
Pour lancer le démon automatiquement au démarrage de Sancho et le couper à la fermeture de Sancho (à la manière de Amule) :
mlnet -start_gui true -mldonkey_gui /usr/local/sancho/sancho
Puis vous pouvez simplement lancer mlnet, le serveur lancera toujours Sancho.
N'oubliez pas d’autoriser Sancho à couper le serveur mldonkey lorsque vous quittez :
outils / préférences :
Pour revenir à la configuration par défaut, éditez le fichier /home/mondossierpersonnel/.mldonkey/download.ini et cherchez la ligne mldonkey_gui
Pour Feisty :
Vous pouvez vous servir d'un ipfilter.dat en le placant dans le dossier ~/.mldonkey
Pour la compatibilité d'un fichier ipfilter.dat :
grep -v ^# ipfilter.dat > ipfilter.p2p
Avec l'interface web, cliquer sur les onglets help+ ⇒ Sysinfo et le troisième tableau affichera la liste des ports utilisés comme présenté ci dessous:
Network | Port|Type ---------- ------ ------------------- BitTorrent| 6882|client_port TCP BitTorrent| 6881|tracker_port TCP Core | 4080|http_port Core | 4000|telnet_port Core | 4001|gui_port Donkey | 4662|client_port TCP Donkey | 4666|client_port UDP Donkey | 14934|overnet_port TCP UDP Donkey | 4672|kademlia_port UDP
En veillant que le démon ne soit pas lancé pendant l'édition, il est possible de modifier ces ports:
éditez le fichier ~/.mldonkey/nomduprotocole.ini
avec nomduprotocole :
À l'aide d'une extension spécialement conçu pour MLDonkey, il est possible de charger des fichiers eDonkey et BitTorrent en un clic. Elle utilise l'interface web WebUI, et permet donc de le faire à distance.
Disponible sur le site des extensions Mozilla: https://addons.mozilla.org/fr/firefox/addon/mldonkeyfox-protocols-handl
Pour l'installation aller voir Firefox
Dernier raffinement, vous pouvez vous créer un script (shell, php, perl, …) qui sera lancé au démarrage et à la récupération d'un fichier. Cela permet d'avertir l'utilisateur, de scanner avec un anti-virus le fichier récupéré, et même de le sortir de l'incoming, pour éviter les problèmes d'upload. Allez voir dans downloads.ini, jusqu'à la commande file_completed. Si il y en a que ça intéresse, je peux joindre la copie de mon script (home made 100% pas propre).
qui peut joindre la copie du script?