Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

minidlna

Introduction

L’accès aux contenus multimédias sur un réseau local est relativement simple lorsque le client est compatible avec le protocole Samba, mais depuis l’arrivée des smartphones, tablettes, et autres TV connectées, il serait dommage de se priver d’un autre protocole : l’UPNP

minidlna est un logiciel serveur UPNP vraiment simple d'utilisation entièrement compatible avec les clients DLNA / UPnP.
Le démon minidlna sert des fichiers multimédias (musiques, photos et vidéos) à des clients sur un réseau.

Installation du paquet

apt-get update && apt-get install minidlna

Configuration

Voici le fichier de configuration /etc/minidlna.conf par défaut:

/etc/minidlna.conf
# port for HTTP (descriptions, SOAP, media transfer) traffic
port=8200
 
# network interfaces to serve, comma delimited
#network_interface=eth0
 
# specify the user account name or uid to run as
#user=jmaggard
 
# set this to the directory you want scanned.
# * if you want multiple directories, you can have multiple media_dir= lines
# * if you want to restrict a media_dir to specific content types, you
#   can prepend the types, followed by a comma, to the directory:
#   + "A" for audio  (eg. media_dir=A,/home/jmaggard/Music)
#   + "V" for video  (eg. media_dir=V,/home/jmaggard/Videos)
#   + "P" for images (eg. media_dir=P,/home/jmaggard/Pictures)
#   + "PV" for pictures and video (eg. media_dir=PV,/home/jmaggard/digital_camera)
media_dir=/opt
 
# set this to merge all media_dir base contents into the root container
# note: the default is no
#merge_media_dirs=no
 
# set this if you want to customize the name that shows up on your clients
#friendly_name=My DLNA Server
 
# set this if you would like to specify the directory where you want MiniDLNA to store its database and album art cache
#db_dir=/var/cache/minidlna
 
# set this if you would like to specify the directory where you want MiniDLNA to store its log file
#log_dir=/var/log
 
# set this to change the verbosity of the information that is logged
# each section can use a different level: off, fatal, error, warn, info, or debug
#log_level=general,artwork,database,inotify,scanner,metadata,http,ssdp,tivo=warn
 
# this should be a list of file names to check for when searching for album art
# note: names should be delimited with a forward slash ("/")
album_art_names=Cover.jpg/cover.jpg/AlbumArtSmall.jpg/albumartsmall.jpg/AlbumArt.jpg/albumart.jpg/Album.jpg/album.jpg/Folder.jpg/folder.jpg/Thumb.jpg/thumb.jpg
 
# set this to no to disable inotify monitoring to automatically discover new files
# note: the default is yes
inotify=yes
 
# set this to yes to enable support for streaming .jpg and .mp3 files to a TiVo supporting HMO
enable_tivo=no
 
# set this to strictly adhere to DLNA standards.
# * This will allow server-side downscaling of very large JPEG images,
#   which may hurt JPEG serving performance on (at least) Sony DLNA products.
strict_dlna=no
 
# default presentation url is http address on port 80
#presentation_url=http://www.mylan/index.php
 
# notify interval in seconds. default is 895 seconds.
notify_interval=900
 
# serial and model number the daemon will report to clients
# in its XML description
serial=12345678
model_number=1
 
# specify the path to the MiniSSDPd socket
#minissdpdsocket=/var/run/minissdpd.sock
 
# use different container as root of the tree
# possible values:
#   + "." - use standard container (this is the default)
#   + "B" - "Browse Directory"
#   + "M" - "Music"
#   + "V" - "Video"
#   + "P" - "Pictures"
#   + Or, you can specify the ObjectID of your desired root container (eg. 1$F for Music/Playlists)
# if you specify "B" and client device is audio-only then "Music/Folders" will be used as root
#root_container=.
 
# always force SortCriteria to this value, regardless of the SortCriteria passed by the client
#force_sort_criteria=+upnp:class,+upnp:originalTrackNumber,+dc:title
 
# maximum number of simultaneous connections
# note: many clients open several simultaneous connections while streaming
#max_connections=50

Maintenant configurons le serveur pour qu’il partage efficacement nos fichiers en modifiant le fichier minidlna.conf avec nano:

nano /etc/minidlna.conf

Le fichier, bien qu’en anglais, est relativement simple à comprendre.

De nombreuses lignes d’options sont commentées, c’est à dire qu’il y a un #2) devant afin que le serveur ne prenne pas ces options en compte.
Nous avons donc le choix :

  1. soit d'enlever ce # devant la ligne afin que l’option soit prise en compte,
  2. soit d'ajouter une ligne équivalente sans ce symbole, cela nous permet de garder à vue la configuration initiale.

Afin que les changements soient pris en compte, chaque modification du fichier de configuration doit être suivie de la commande suivante :

service minidlna restart

Port

Modifions la valeur par défaut du port et mettre

port=49200

Network interface

Spécifions notre interface de réseau, généralement etho ou eth1 suivant votre carte réseau. \ La commande :

ifconfig

nous donnera rapidement la réponse.

Par câble ethernet

network_interface=eth0

Par WI-FI

network_interface=wlan0

Par câble ethernet et par WI-FI dans le cas de plusieurs réseaux il faut prendre garde à bien séparer par des virgules les interfaces réseau ainsi :

network_interface=eth0,wlan0

Partage des dossiers

Une autre option importante à configurer, c'est de mettre en place les partages.
minidlna permet de trier nos fichiers par type de média, il suffit de lui préciser si ce sont des vidéos, des images, ou des fichiers audios.
Chacun de ces types est désigné par une lettre :

  • V pour les vidéos
  • P pour les images
  • A pour les fichiers audios.

Par exemple, pour partager les fichiers vidéos situés dans un répertoire /medias/films/, voici la ligne à entrer :

media_dir=V,/medias/films

Notez que le type de média n’a pas besoin d’être précisé si tous nos médias sont situés dans le répertoire /home/utilisateur, la ligne media_dir=/home/utilisateur suffira.

Pour nous simplifier la navigation plusieurs partages peuvent être ajoutés.
Nous pouvons par exemple choisir de séparer nos vidéos par type en mettant d’un coté les films et d’un autre les vidéos de famille.

Par exemple :
media_dir=/home/utilisateur/film
media_dir=/home/utilisateur/videos_famille

Nom interface

Modifions le nom qui apparaîtra sur l’interface des clients ou celui qui apparaîtra sur l'interface du client DLNA (télévisions, smartphones, tablettes…)
De base, le nom n’est pas très explicite, et il sera sûrement plus agréable de lire à la place par exemple : « Serveur DLNA Debian ».
:-)

Dans ce cas l’option à modifier est « friendly_name= »
Ce qui nous donnera pour cet exemple :

friendly_name=Serveur DLNA Debian

Répertoire du cache

Ajoutons cette ligne :

db_dir=/var/cache/minidlna

Recherche nouveaux fichiers

Pour ne pas être obligé de lancer un scan des fichiers à chaque fois que nous en ajoutons, vérifions que la ligne « inotify= » est bien réglée sur « yes » :

inotify=yes

notify interval

Si le serveur n'apparaît pas sur le client, nous pouvons baisser le notify interval par exemple à 60, c'est a dire qu'il va attendre 60 secondes pour lancer une recherche de media ajouté.

notify_interval=60

Augmenter le nombre d'entrées

Il arrive parfois (lorsqu'il y a un grand nombre de fichiers) que la base de données ne veuille plus se mettre à jour.
Il faut alors demander au noyau d'augmenter le nombre d'entrées qu'inotify peut créer, avec la commande suivante :

sysctl fs.inotify.max_user_watches=100000

Si nous voulons que la modification soit permanente, il faut plutôt choisir de modifier le fichier : /etc/sysctl.conf, en y ajoutant fs.inotify.max_user_watches = 100000 à la fin :

nano /etc/sysctl.conf
fs.inotify.max_user_watches = 100000

Enregistrement des configurations

Une fois toutes les modifications faites enregistrons-les via les touches F3 ou Ctrl+O puis validons par ↵ Entrée.
Nous pouvons enfin quitter nano via les touches F2 ou Ctrl+X

Lancement de minidlna et scan

Une fois que nous avons terminé de configurer le programme, lançons minidlna ainsi :

service minidlna start

Puis, il faut demander à minidlna de scanner une première fois nos médias afin de les rendre disponibles :

service minidlna force-reload

C'est tout ! :-)

Maintenant nos médias qui se trouvent sur notre OS préféré seront détectés par les autres périphériques dotés du protocole DLNA / UPnP.

Fichier configuration simplifié

Voici un exemple de fichier de configuration très simplifié et sans les commentaires.

Dans les sections media_dir ne pas oublier de changer $USER par notre nom d'utilisateur

port=49200
network_interface=eth0,wlan0
#user=jmaggard
media_dir=V,/home/$USER/Vidéo
media_dir=P,/home/$USER/Images
media_dir=A,/home/$USER/Musique
#merge_media_dirs=no
friendly_name=Serveur DLNA Debian
db_dir=/var/cache/minidlna
#log_dir=/var/log
#log_level=general,artwork,database,inotify,scanner,metadata,http,ssdp,tivo=warn
album_art_names=Cover.jpg/cover.jpg/AlbumArtSmall.jpg/albumartsmall.jpg/AlbumArt.jpg/albumart.jpg/Album.jpg/album.jpg/Folder.jpg/folder.jpg/Thumb.jpg/thumb.jpg
inotify=yes
enable_tivo=no
strict_dlna=no
notify_interval=60
serial=12345678
model_number=1
#root_container=.
#max_connections=50

Liste de commandes utiles

Lancer minidlna

service minidlna start

Reancer minidlna

service minidlna restart

Arrêter minidlna

service minidlna stop

Connaître le status

/service minidlna status

Scanner / reconstruire la base de données

service minidlna force-reload

Pour plus d'info sur minidlna consultez le manuel : ;-)

man minidlna
1) N'hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !
doc/reseau/minidlna.txt · Dernière modification: 30/10/2016 08:12 par Slyfox

Pied de page des forums

Propulsé par FluxBB