File: mpd.conf.5.rst

package info (click to toggle)
mpd 0.24.8-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 10,760 kB
  • sloc: cpp: 75,041; python: 1,408; xml: 628; perl: 469; java: 289; sh: 286; ansic: 235; makefile: 105
file content (303 lines) | stat: -rw-r--r-- 8,330 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
.. _manpage_mpdconf:

========
mpd.conf
========


Description
------------

:file:`mpd.conf` is the configuration file for :manpage:`mpd(1)`.

Usually, that is :file:`/etc/mpd.conf`, unless a different path is
specified on the command line.

If you run :program:`MPD` as a user daemon (and not as a system
daemon), the configuration is read from
:file:`$XDG_CONFIG_HOME/mpd/mpd.conf` (usually
:file:`~/.config/mpd/mpd.conf`). On Android, :file:`mpd.conf` will be
loaded from the top-level directory of the data partition.

Each line in the configuration file contains a setting name and its value, e.g.:

:code:`connection_timeout "5"`

Lines starting with ``#`` are treated as comments and ignored.

For settings that specify a file system path, the tilde (``~``) is
expanded to ``$HOME``. In addition, the following path expansions are
supported:

- ``$HOME``
- ``$XDG_CONFIG_HOME``
- ``$XDG_MUSIC_DIR``
- ``$XDG_CACHE_HOME``
- ``$XDG_RUNTIME_DIR``

Example:

.. code-block:: none

    music_directory "~/Music"
    db_file "$XDG_CONFIG_HOME/mpd/database"

Some of the settings are grouped in blocks with curly braces, e.g. per-plugin settings:

.. code-block:: none

   audio_output {
       type "alsa"
       name "My ALSA output"
       device "iec958:CARD=Intel,DEV=0"
       mixer_control "PCM"
   }

The :code:`include` directive can be used to include settings from
another file; the given file name is relative to the current file:

.. code-block:: none

  include "other.conf"

You can use :code:`include_optional` instead if you want the included file
to be optional; the directive will be ignored if the file does not exist:

.. code-block:: none

  include_optional "may_not_exist.conf"

See :file:`docs/mpdconf.example` in the source tarball for an example
configuration file.

This manual is not complete, it lists only the most important options.
Please read the MPD user manual for a complete configuration guide:
http://www.musicpd.org/doc/user/

Global Settings
---------------

System Settings
^^^^^^^^^^^^^^^

.. confval:: user
   :type: NAME

   This specifies the user that MPD will run as, if set. MPD should never run
   as root, and you may use this option to make MPD change its user id after
   initialization. Do not use this option if you start MPD as an unprivileged
   user.

.. confval:: group
   :type: NAME

   Change to this group.  This discards all default groups and uses
   only this group.  Do not use this setting.

.. confval:: pid_file
   :type: PATH

   This specifies the file to save mpd's process ID in.

.. confval:: log_file
   :type: PATH

   This specifies where the log file should be located. The special value "syslog" makes MPD use the local syslog daemon.

.. confval:: log_level
   :type: LEVEL
   :default: ``notice``

   Suppress all messages below the given threshold.  The following
   log levels are available:

   - :samp:`error`: errors
   - :samp:`warning`: warnings
   - :samp:`notice`: interesting informational messages
   - :samp:`info`: unimportant informational messages
   - :samp:`verbose`: debug messages (for developers and for
     troubleshooting)


Client Settings
^^^^^^^^^^^^^^^

.. confval:: port
   :type: number
   :default: :samp:`6600`

   This specifies the port that mpd listens on.


File Settings
^^^^^^^^^^^^^

.. confval:: db_file
   :type: PATH

   This specifies where the db file will be stored.

.. confval:: sticker_file
   :type: PATH

   The location of the sticker database. This is a database which manages
   dynamic information attached to songs.

.. confval:: music_directory
   :type: PATH

   This specifies the directory where music is located. If you do not configure
   this, you can only play streams.

.. confval:: playlist_directory
   :type: PATH

   This specifies the directory where saved playlists are stored
   (flat, no subdirectories).  If you do not configure this, you
   cannot save playlists.

.. confval:: state_file
   :type: PATH

   This specifies if a state file is used and where it is located. The state of
   mpd will be saved to this file when mpd is terminated by a TERM signal or by
   the :program:`kill` command. When mpd is restarted, it will read the state file and
   restore the state of mpd (including the playlist).

.. confval:: follow_outside_symlinks
   :type: ``yes`` or ``no``
   :default: ``yes``

   Control if MPD will follow symbolic links pointing outside the music dir. You
   must recreate the database after changing this option.

.. confval:: follow_inside_symlinks
   :type: ``yes`` or ``no``
   :default: ``yes``

   Control if MPD will follow symbolic links pointing inside the music dir,
   potentially adding duplicates to the database. You must recreate the
   database after changing this option.

.. confval:: auto_update
   :type: ``yes`` or ``no``
   :default: ``no``

   This specifies the whether to support automatic update of music database
   when files are changed in music_directory.
   (Only implemented on Linux.)

.. confval:: auto_update_depth
   :type: number
   :default: unlimited

   Limit the depth of the directories being watched, 0 means only watch the
   music directory itself.

.. confval:: save_absolute_paths_in_playlists
   :type: ``yes`` or ``no``
   :default: ``no``

   This specifies whether relative or absolute paths for song filenames are used
   when saving playlists.

.. confval:: filesystem_charset
   :type: CHARSET

   This specifies the character set used for the filesystem. A list of supported
   character sets can be obtained by running "iconv -l". The default is
   determined from the locale when the db was originally created.


Player Settings
^^^^^^^^^^^^^^^

.. confval:: restore_paused
   :type: ``yes`` or ``no``
   :default: ``no``

   Put MPD into pause mode instead of starting playback after startup.


Other Settings
^^^^^^^^^^^^^^

.. confval:: zeroconf_enabled
   :type: ``yes`` or ``no``
   :default: ``yes``

   If yes, and MPD has been compiled with support for Avahi or Bonjour, service
   information will be published with Zeroconf.

.. confval:: zeroconf_name
   :type: NAME
   :default: :samp:`Music Player @ %h`

   If Zeroconf is enabled, this is the service name to publish. This
   name should be unique to your local network, but name collisions
   will be properly dealt with.  ``%h`` will be replaced with the
   hostname of the machine running MPD.

.. confval:: audio_output

   See DESCRIPTION and the various ``AUDIO OUTPUT OPTIONS`` sections for the
   format of this block. Multiple audio_output sections may be specified. If
   no audio_output section is specified, then MPD will scan for a usable audio
   output.

Required Audio Output Settings
------------------------------

.. confval:: type
   :type: NAME

   This specifies the audio output type. See the list of supported outputs in
   ``mpd --version`` for possible values.

.. confval:: name
   :type: NAME

   This specifies a unique name for the audio output.

Optional Audio Output Settings
------------------------------

.. confval:: format
   :type: ``sample_rate:bits:channels``

  This specifies the sample rate, bits per sample, and number of channels of
  audio that is sent to the audio output device. See documentation for the
  ``audio_output_format`` option for more details. The default is to use
  whatever audio format is passed to the audio output. Any of the three
  attributes may be an asterisk to specify that this attribute should not be
  enforced

.. confval:: replay_gain_handler
   :type: ``software``, ``mixer`` or ``none``
   :default: ``software``

   Specifies how replay gain is applied. ``software`` uses an internal
   software volume control. ``mixer`` uses the configured (hardware)
   mixer control. ``none`` disables replay gain on this audio output.

.. confval:: mixer_type
   :type:  ``hardware``, ``software`` or ``none``
   :default: ``hardware`` (if supported) or ``none``

   Specifies which mixer should be used for this audio output: the hardware
   mixer (available for ALSA, OSS and PulseAudio), the software mixer or no
   mixer (``none``).

Files
-----

:file:`$XDG_CONFIG_HOME/mpd/mpd.conf`
  User configuration file (usually :file:`~/.config/mpd/mpd.conf`).

:file:`/etc/mpd.conf`
  Global configuration file.

See Also
--------

:manpage:`mpd(1)`, :manpage:`mpc(1)`