logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

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

Ceci est une ancienne révision du document !


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 (musique, photos et vidéo) à des clients sur un réseau.

Installation du paquet

apt-get install minidlna

Configuration

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

# 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.
Pour cela, il suffit de modifier le fichier minidlna.conf. Pour cela, on se sert de 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 # 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 nous ajoutez une ligne équivalente sans ce symbole afin 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 bien séparer par des virgules les interfaces réseau.

network_interface=eth0,wlan0

Partage des dossiers

Autre option importante, mettre en place les partages.
minidlna permet de trier nos fichiers part type de média.
Il nous suffit de préciser si ce sont des vidéos, des images, ou des fichiers audios, chaque type étant désigné par une lettre :

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

Pour partager par exemple les fichiers vidéos situés dans le 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.

Nous pouvons en plus 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, pour nous simplifier la navigation au sein de nos médias, plusieurs partages peuvent être ajoutés.
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 ce que vous voulez voir apparaître sur l'interface du client DLNA (télévisions, smartphones, tablettes…)
De base, le nom n’est pas très explicite, et il nous sera sûrement plus agréable de lire par exemple « Serveur DLNA Debian » à la place.

Dans ce cas l’option à modifier est « friendly_name= »

Ce qui nous donne par exemple :

friendly_name=Serveur DLNA Debian

Répertoire du cache

Mettons

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 de nouveaux, 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 à 10, 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 alors modifier le fichier /etc/sysctl.conf, en y ajoutant fs.inotify.max_user_watches = 100000 à la fin de ce fichier.

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

Enregistrement des configurations

Une fois toutes les modifications faite: Enregistrons les modifications 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, il nous suffit de lancer minidlna :

service minidlna start

Ceci fait, il faut demander à minidlna de scanner nos médias une première fois pour les rendre immédiatement disponibles.

service minidlna force-reload

C'est tout ! :-)

Maintenant nos médias qui se trouvent sur notre OS préféré seront normalement 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 “utilisateur” par notre nom d'utilisateur
port=49200
network_interface=eth0,wlan0
#user=jmaggard
media_dir=V,/home/utilisateur/Video
media_dir=P,/home/utilisateur/Images
media_dir=A,/home/utilisateur/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 consultons le manuel ;-)

man minidlna
1)
N'hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !
doc/reseau/minidlna.1446396881.txt.gz · Dernière modification: 01/11/2015 17:54 par Slyfox

Pied de page des forums

Propulsé par FluxBB