First and foremost, the reference to the awesome projects:
Music Player Daemon
MPDScribble
Please see the Goal.
Please note that support goal is limited to cover running costs for subscriptions to music services.
A docker image for mpd with support for both Alsa and PulseAudio.
The container image also includes mpdscribble. In alternative, you can use mpd-scrobbler-docker as the scrobbler for this image.
User mode is now possible when using alsa outputs, and of course it is mandatory (enforced) when using pulse outputs.
Upsampling (even in integer mode) is now available via a patched version of MPD (an unmodified version is available as well).
Also, thanks to a feature request by user XxAcielxX, who also contributed with the necessary documentation, we have a certain degree of support for equalization.
As an alternative, if you don't want to use docker for an audio player, and still would prefer to run mpd using environment variables instead of maintaining your mpd.conf files and bothering with creating the directory structure, take a look at my new project player-launchers. It is still in the initial development phases, but the mpd launcher has quite some options already in place.
- linux/amd64
- linux/arm/v7
- linux/arm64/v8
- linux/arm/v6 (for debian-based builds)
- linux/arm/v5 (for debian-based builds)
Source: GitHub
Images: DockerHub
I prepared this Dockerfile because I wanted to be able to install mpd easily on any machine (provided the architecture is amd64 or arm). Also I wanted to be able to configure and govern the parameters easily, allowing multiple output, also of different types.
See this page.
Here is the repository on DockerHub.
Getting the image from DockerHub is as simple as typing:
docker pull giof71/mpd-alsa
Legacy support OUTPUT_MODE, is still available in the legacy branch, as well as on the images tagged with the legacy prefix.
You might want to use those releases as a stop-gap solution should you encounter issues migrating to the new configuration methods.
Keep in mind that the legacy branch will not be updated with new features. Only relevant bugfix changes will be ported there.
The source code for the patched MPD is in this GitHub repo.
The version-0.24.6 tag is in-line with the GitHub upstream repo at version 0.24.6.
The version-0.24.6-ups tag contains a patch which is used when INTEGER_UPSAMPLING is set to yes. Use at your own risk.
Two binaries are available in the container image:
- /app/bin/compiled/mpd (upstream version)
- /app/bin/compiled/mpd-ups (patched version)
The current mpd version is v0.24.6 when using giof71/mpd-compiler-docker as the base image (Docker Repo here). The repo binary is installed also in this case.
Vanilla versions only have the repo binary.
The mpdscribble version depends on the base image. See the following table:
| Base Image | Tags | Compiled MPD version | Repo MPD version | MPDScribble version | 
|---|---|---|---|---|
| giof71/mpd-compiler:bookworm | latest, stable, bookworm | 0.24.6 | 0.23.12 | 0.24 | 
| debian:bookworm-slim | vanilla-latest, vanilla-stable, vanilla, vanilla-bookworm | - | 0.23.12 | 0.24 | 
Starting with release 2023-02-04, you will not be able to use the deprecated PULSE and ALSA as OUTPUT_MODE. Refer to the next chapter for more information about how to change the configuration. Please note that Alsa and PulseAudio are still supported: you just need to slightly modify your docker configurations.
In case of difficulties, you can fall back to the legacy image versions (e.g.: giof71/mpd-alsa:legacy-latest), as those will still work with these deprecated configurations.
If you have been using this container image for a while, you might have seen that the output might contain some warnings, telling you that you are using a deprecated configuration. The message usually tries to suggest how to switch to a recommended configuration.
This is happening because this whole project started with the idea of supporting ALSA only (hence the name mpd-alsa-docker). Down the road, I added PulseAudio support, and eventually HTTPD outputs, SHOUTCAST outputs, also in multiple instances.
So now a few variables have a misleading name: the most misleading being ALSA_DEVICE_NAME which, despite the name, refers to the output name, and not to the device name.
So currently, OUTPUT_MODE is not available anymore.
In any case, I suggest you change the configuration as suggested, and use the variables from the appropriate sections below for Alsa and PulseAudio, otherwise, in time, your configurations will not be functional anymore.
Please refer to the legacy branch for the old documentation.
Feel free to contact me with an issue if you need support. I cannot guarantee a timing, but I will try to help if I can.
See this page.
The following tables lists the volumes:
| VOLUME | DESCRIPTION | 
|---|---|
| /db | Where the mpd database is saved | 
| /music | Where the music is stored. You might consider to mount your directory in read-only mode ( :ro) | 
| /playlists | Where the playlists are stored | 
| /log | Where all logs are written (e.g. mpd.log,scrobbler.logetc) | 
| /user/config | Additional user-provided configuration files, see this paragraph for the details | 
Several files can be located in the user configuration (/user/config) volume. Here is a table of those files.
| FILE | DESCRIPTION | 
|---|---|
| lastfm.txt | LastFM Credentials | 
| librefm.txt | LibreFM Credentials | 
| jamendo.txt | Jamendo Credentials | 
| additional-alsa-presets.conf | Additional alsa presets | 
| additional-outputs.txt | Additional outputs, which will be added to the configuration file during the container startup phase | 
| asoundrc.txt | Alsa configuration file: this will be copied to /home/mpd-user/.asoundrcor to/root/.asoundrc, depending on user mode to be enabled or not | 
| override.mpd.conf | User provided mpd configuration file (see #356). Use at your own risk. If this file is available, it will be used in the final phase of the run script instead of the generated file. | 
For a reference for the structure of the credentials file, see the corresponding example file in the doc folder of the repository.
The following tables lists all the currently supported environment variables:
| VARIABLE | DESCRIPTION | 
|---|---|
| DATABASE_MODE | Can be simple(default),proxyorupnp(requireshostnetworking) | 
| DATABASE_PROXY_HOST | MPD server hostname, only used when DATABASE_MODEis set toproxy | 
| DATABASE_PROXY_PORT | MPD server port, only used when DATABASE_MODEis set toproxy | 
| DATABASE_PROXY_PASSWORD | The password used to log in to the masterMPD instance, only used whenDATABASE_MODEis set toproxy | 
| DATABASE_PROXY_KEEPALIVE | Send TCP keepalive packets to the masterMPD instance (yesorno), only used whenDATABASE_MODEis set toproxy | 
| MUSIC_DIRECTORY | Location of music files, defaults to /music | 
| MPD_BIND_ADDRESS | The MPD listen address, more than one can be specified (just use MPD_BIND_ADDRESS_1,MPD_BIND_ADDRESS_2, etc), defaults to0.0.0.0 | 
| MPD_PORT | The MPD port, defaults to 6600 | 
| USER_MODE | Set to yoryesfor user mode. Case insensitive. See User mode. Required when using any PulseAudio outputs (so whenPULSE_AUDIO_OUTPUT_CREATEis set toyes) | 
| PUID | User id. Defaults to 1000. The user/group will be created when a PulseAudio output is created unlessUSER_MODEis set tono. | 
| PGID | Group id. Defaults to 1000. The user/group will be created when a PulseAudio output is created unlessUSER_MODEis set tono. | 
| AUDIO_GID | audiogroup id from the host machine. Mandatory foralsaoutput in user mode. See User mode. | 
| INPUT_CACHE_SIZE | Sets the input cache size. Example value: 1 GB | 
| SAMPLERATE_CONVERTER | Configure samplerate_converter. Example value:soxr very high. Note that this configuration cannot be used whenSOXR_PLUGIN_ENABLEis set to enabled. There are some preset values for sox:very_highandvery-highmap tosoxr very high,highmaps tosoxr high,mediummaps tosoxr medium,lowmaps tosoxr lowandquickmaps tosoxr quick. Refer to this page for details. | 
| MPD_ENABLE_LOGGING | Defaults to yes, set tonoto disable | 
| MPD_LOG_LEVEL | Can be defaultorverbose | 
| FFMPEG_ENABLED | Enable ffmpeg decoder, defaults to no. Plugin documentation here | 
| CURL_ENABLED | Enable CURL input plugin, defaults to yes. This is required if you plan to use upmpdcli. Input plugin documentation here | 
| CURL_PROXY | Parameter for CURL input plugin | 
| CURL_PROXY_USER | Parameter for CURL input plugin | 
| CURL_PROXY_PASSWORD | Parameter for CURL input plugin | 
| CURL_VERIFY_PEER | Parameter for CURL input plugin | 
| CURL_VERIFY_HOST | Parameter for CURL input plugin | 
| CURL_CACERT | Parameter for CURL input plugin | 
| ZEROCONF_ENABLED | Set to yesto enable, disabled by default. | 
| ZEROCONF_NAME | Set zeroconf name, used only if ZEROCONF_ENABLEDis set toyes | 
| HYBRID_DSD_ENABLED | Hybrid dsd is enabled by default, set to noto disable. Disabled when at least one PulseAudio output is created. | 
| OPUS_DECODER_ENABLED | Defaults to yes, if set tono, the opus decoder will be disabled. | 
| MIXRAMP_ANALYZER_ENABLED | Enable MixRamp support. Set to yesto enable | 
| AUDIO_BUFFER_SIZE | Adjust the size of the internal audio buffer. Default is 4 MB(4 MiB). | 
| MAX_ADDITIONAL_OUTPUTS_BY_TYPE | The maximum number of outputs by type, defaults to 20 | 
| RESTORE_PAUSED | If set to yes, then MPD is put into pause mode instead of starting playback after startup. Default isno. | 
| STATE_FILE_INTERVAL | Auto-save the state file this number of seconds after each state change, defaults to 10seconds | 
| ENFORCE_PLAYER_STATE | If set to yes, it will remove player state information from the state file, so the player state will only depend on the environment variables. Defaults toyes | 
| FORCE_REPO_BINARY | If set to yes, the binary from the distro repository will be used | 
| DEFAULT_PERMISSIONS | Sets default_permissions, see here | 
| LOCAL_PERMISSIONS | Sets local_permissions, see here | 
| HOST_PERMISSIONS | Adds a host_permissions, you can add multiple (up toMAX_PERMISSIONS), append_1,_2, etc to the variable name for additional entries, see here | 
| PASSWORD | Adds a password, you can add multiple (up toMAX_PERMISSIONS), append_1,_2, etc to the variable name for additional entries, see here | 
| MAX_PERMISSIONS | Specify the maximum number of host_permissions and passwords, defaults to 10 | 
| STDERR_ENABLED | Print messages to the standard error, enabled by default. Set to noto disable | 
| CONNECTION_TIMEOUT | If a client does not send any new data in this time period (seconds), the connection is closed. Clients waiting in “idle” mode are excluded from this. Default is 60 | 
| MAX_CONNECTIONS | This specifies the maximum number of clients that can be connected to MPD at the same time, default is 100 | 
| MAX_PLAYLIST_LENGTH | The maximum number of songs that can be in the playlist, default is 16384 | 
| MAX_COMMAND_LIST_SIZE | The maximum size a command list in KBYTES, default is 2048(2 MiB) | 
| MAX_OUTPUT_BUFFER_SIZE | The maximum size of the output buffer to a client (maximum response size), in KBYTES, default is 8192 (8 MiB) | 
| AUTO_UPDATE | Set to yesto enable autoupdate of database | 
| AUTO_UPDATE_DEPTH | Limit the depth of the directories being watched, 0means only watch the music directory itself. There is no limit by default. | 
| STARTUP_DELAY_SEC | Delay before starting the application in seconds, defaults to 0 | 
Please find here the variables used to configure the SOXR plugin.
| VARIABLE | DESCRIPTION | 
|---|---|
| SOXR_PLUGIN_ENABLE | Enable the soxrplugin. Do not use in conjunction with variableSAMPLERATE_CONVERTER | 
| SOXR_PLUGIN_PRESET | Presets for SOXR_PLUGIN configuration. Available presets: goldilocksandextremus | 
| SOXR_PLUGIN_THREADS | The number of libsoxr threads. 0means automatic. The default is1which disables multi-threading. | 
| SOXR_PLUGIN_QUALITY | The quality of soxrresampler. Possible values:very high,high(the default),medium,low,quick,custom. When set tocustom, the additionalsoxrparameters can be set. | 
| SOXR_PLUGIN_PRECISION | The precision in bits. Valid values 16,20,24,28and32bits. | 
| SOXR_PLUGIN_PHASE_RESPONSE | Between the 0-100, where 0is MINIMUM_PHASE and50is LINEAR_PHASE | 
| SOXR_PLUGIN_PASSBAND_END | The % of source bandwidth where to start filtering. Typical between the 90-99.7. | 
| SOXR_PLUGIN_STOPBAND_BEGIN | The % of the source bandwidth Where the anti aliasing filter start. Value 100+. | 
| SOXR_PLUGIN_ATTENUATION | Reduction in dB’s to prevent clipping from the resampling process | 
| SOXR_PLUGIN_FLAGS | Bitmask with additional options, see soxr documentation for specific flags | 
Please find here the variables used to configure ReplayGain.
| VARIABLE | DESCRIPTION | 
|---|---|
| REPLAYGAIN_MODE | ReplayGain Mode, defaults to off | 
| REPLAYGAIN_PREAMP | ReplayGain Preamp, defaults to 0 | 
| REPLAYGAIN_MISSING_PREAMP | ReplayGain missing preamp, defaults to 0 | 
| REPLAYGAIN_LIMIT | ReplayGain Limit, defaults to yes | 
| VOLUME_NORMALIZATION | Volume normalization, defaults to no | 
Please find here the variables used to configure the Qobuz plugin.
| VARIABLE | DESCRIPTION | 
|---|---|
| QOBUZ_PLUGIN_ENABLED | Enables the Qobuz plugin, defaults to no | 
| QOBUZ_APP_ID | Qobuz application id | 
| QOBUZ_APP_SECRET | Your Qobuz application Secret | 
| QOBUZ_USERNAME | Qobuz account username | 
| QOBUZ_PASSWORD | Qobuz account password | 
| QOBUZ_FORMAT_ID | The Qobuz format identifier, i.e. a number which chooses the format and quality to be requested from Qobuz. The default is 5(320 kbit/s MP3). | 
Please find here the variables used to configure scrobbling. All of those are of course optional.
Credentials of course go in pairs, so in order to enable one serve, you must provide both username and password.
| VARIABLE | DESCRIPTION | 
|---|---|
| LASTFM_USERNAME | Username for Last.fm | 
| LASTFM_PASSWORD | Password for Last.fm | 
| LIBREFM_USERNAME | Username for Libre.fm | 
| LIBREFM_PASSWORD | Password for Libre.fm | 
| JAMENDO_USERNAME | Username for Jamendo | 
| JAMENDO_PASSWORD | Password for Jamendo | 
| SCRIBBLE_VERBOSE | How verbose mpdscribble's logging should be. Default is 1. | 
| SCROBBLER_MPD_HOSTNAME | Set when using host mode, defaults to localhost | 
| SCROBBLER_MPD_PORT | Set when using host mode, defaults to 6600 | 
| PROXY | Proxy support for mpdscribble. Example value:http://the.proxy.server:3128 | 
You can define additional outputs of various types. Refer to the following paragraphs.
For each type, that you can add up to 20 (or what is specified for the variable MAX_ADDITIONAL_OUTPUTS_BY_TYPE) additional outputs for each type. In order to specify distinct values, you can add _1, _2 to every variable names in this set. The first output does not require to specify _0, that index is implicit.
The output name of those outputs, if not explicitly set, is created by appending with _1, _2, ... to the defaut name, so in the case of PulseAudio, the names of output will be PulseAudio_1, PulseAudio_2, ...
Additional alsa outputs can be configured using the following variables:
| VARIABLE | DESCRIPTION | 
|---|---|
| ALSA_OUTPUT_CREATE | Set to yesif you want to create an additional alsa output | 
| ALSA_OUTPUT_ENABLED | Sets the output as enabled if set to yes, otherwise mpd's default behavior applies | 
| ALSA_OUTPUT_NAME | The name of the alsa output, defaults to alsa | 
| ALSA_OUTPUT_PRESET | Use an Alsa preset for easier configuration | 
| ALSA_OUTPUT_DEVICE | The audio device. Common examples: hw:DACorhw:x20orhw:X20for usb dac based on XMOS chips. Defaults todefault | 
| ALSA_OUTPUT_AUTO_FIND_MIXER | Allows to auto-select the mixer for easy hardware volume configuration | 
| ALSA_OUTPUT_MIXER_TYPE | Mixer type, defaults to hardware | 
| ALSA_OUTPUT_MIXER_DEVICE | Mixer device, defaults to default | 
| ALSA_OUTPUT_MIXER_CONTROL | Mixer Control, defaults to PCM | 
| ALSA_OUTPUT_MIXER_INDEX | Mixer Index, defaults to 0 | 
| ALSA_OUTPUT_ALLOWED_FORMATS_PRESET | Alternative to ALSA_OUTPUT_ALLOWED_FORMATS. Possible values: 8x, 4x, 2x, 8x-nodsd, 4x-nodsd, 2x-nodsd | 
| ALSA_OUTPUT_ALLOWED_FORMATS | Sets allowed formats | 
| ALSA_OUTPUT_FORMAT | Sets output format | 
| ALSA_OUTPUT_AUTO_RESAMPLE | If set to no, then libasound will not attempt to resample. In this case, the user is responsible for ensuring that the requested sample rate can be produced natively by the device, otherwise an error will occur. | 
| ALSA_OUTPUT_STOP_DSD_SILENCE | If enabled, silence is played before manually stopping playback (“stop” or “pause”) in DSD mode (native DSD or DoP). This is a workaround for some DACs which emit noise when stopping DSD playback. Can be left blank or to yesorno | 
| ALSA_OUTPUT_THESYCON_DSD_WORKAROUND | If enabled, enables a workaround for a bug in Thesycon USB audio receivers. On these devices, playing DSD512 or PCM causes all subsequent attempts to play other DSD rates to fail, which can be fixed by briefly playing PCM at 44.1 kHz. Can be left blank or to yesorno | 
| ALSA_OUTPUT_INTEGER_UPSAMPLING | If one or more ALSA_ALLOWED_FORMATSare set andINTEGER_UPSAMPLINGis set toyes, the formats which are evenly divided by the source sample rate are preferred. TheALSA_ALLOWED_FORMATSlist is processed in order as provided to the container. So if you want to upsample, put higher sampling rates first. Using this feature causes a patched version of mpd to be run. Use at your own risk. | 
| ALSA_OUTPUT_INTEGER_UPSAMPLING_ALLOWED | Allows selection of sample rates to be upsampled. If set, only specified values are allowed. The values should respect the same format user for ALSA_OUTPUT_ALLOWED_FORMATS | 
| ALSA_OUTPUT_INTEGER_UPSAMPLING_ALLOWED_PRESET | Preset for ALSA_OUTPUT_INTEGER_UPSAMPLING_ALLOWED. Allowed values arebase(for 44.1kHz and 48.0kHz) and44for 44.1kHz only | 
| ALSA_OUTPUT_DOP | Enables Dsd-Over-Pcm. Possible values: yesorno. Empty by default: this it lets mpd handle dop setting. | 
Refer to the MPD documentation for the meaning of the variables.
Remember to setup user mode when using PulseAudio outputs, otherwise they won't work.
Additional PulseAudio outputs can be configured using the following variables:
| VARIABLE | DESCRIPTION | 
|---|---|
| PULSE_AUDIO_OUTPUT_CREATE | Set to yesif you want to create an additional PulseAudio output | 
| PULSE_AUDIO_OUTPUT_ENABLED | Sets the output as enabled if set to yes, otherwise mpd's default behavior applies | 
| PULSE_AUDIO_OUTPUT_NAME | The name of the PulseAudio output, defaults to PulseAudio | 
| PULSE_AUDIO_OUTPUT_SINK | Specifies the name of the PulseAudio sink MPD should play on | 
| PULSE_AUDIO_OUTPUT_MEDIA_ROLE | Media role for the PulseAudio output | 
| PULSE_AUDIO_OUTPUT_SCALING_FACTOR | Scaling factor for the PulseAudio output | 
Refer to the MPD documentation for the meaning of the variables.
Additional httpd outputs can be configured using the following variables:
| VARIABLE | DESCRIPTION | 
|---|---|
| HTTPD_OUTPUT_CREATE | Set to yesif you want to create an additional httpd output | 
| HTTPD_OUTPUT_ENABLED | Sets the output as enabled if set to yes, otherwise mpd's default behavior applies | 
| HTTPD_OUTPUT_NAME | The name of the httpd output, defaults to httpd | 
| HTTPD_OUTPUT_PORT | The port for the httpd output stream, defaults to 8000if not specified | 
| HTTPD_OUTPUT_BIND_TO_ADDRESS | Allows to specify the bind address | 
| HTTPD_OUTPUT_ENCODER | The encoder defaults to wave, see here for other options | 
| HTTPD_OUTPUT_ENCODER_BITRATE | Encoder bitrate. Refer to the encoder documentation | 
| HTTPD_OUTPUT_ENCODER_QUALITY | Encoder quality. Refer to the encoder documentation | 
| HTTPD_OUTPUT_MAX_CLIENTS | Sets a limit, number of concurrent clients. When set to 0 no limit will apply. Defaults to 0 | 
| HTTPD_OUTPUT_ALWAYS_ON | If set to yes, then MPD attempts to keep this audio output always open. This may be useful for streaming servers, when you don’t want to disconnect all listeners even when playback is accidentally stopped. Defaults toyes | 
| HTTPD_OUTPUT_TAGS | If set to no, then MPD will not send tags to this output. This is only useful for output plugins that can receive tags, for example the httpd output plugin. Defaults to yes | 
| HTTPD_OUTPUT_FORMAT | The output format, defaults to 44100:16:2 | 
| HTTPD_OUTPUT_MIXER_TYPE | Set to softwareif you want to be able to change the volume of the output stream | 
The port number default is calculated for each index by incrementing the default (8000) value.
When using multiple httpd outputs, remember to open all the relevant ports, not only 8000, otherwise only the first output will work.
| VARIABLE | DESCRIPTION | 
|---|---|
| SHOUT_OUTPUT_CREATE | Set to yesif you want to create an additional shout output | 
| SHOUT_OUTPUT_ENABLED | Sets the output as enabled if set to yes, otherwise mpd's default behavior applies | 
| SHOUT_OUTPUT_NAME | The name of the shout output, defaults to shout | 
| SHOUT_OUTPUT_PROTOCOL | Specifies the protocol that wil be used to connect to the server, can be icecast2(default),icecast1,shoutcast | 
| SHOUT_OUTPUT_TLS | Specifies what kind of TLS to use, can be disabled(default),auto,auto_no_plain,rfc2818,rfc2817 | 
| SHOUT_OUTPUT_FORMAT | The output format, defaults to 44100:16:2 | 
| SHOUT_OUTPUT_ENCODER | The encoder defaults to vorbis, see here for other options. BITRATE and QUALITY are typically alternative, so do not specify both of them. | 
| SHOUT_OUTPUT_ENCODER_BITRATE | Encoder bitrate. Refer to the encoder documentation | 
| SHOUT_OUTPUT_ENCODER_QUALITY | Encoder quality. Refer to the encoder documentation | 
| SHOUT_OUTPUT_HOST | Sets the host name of the ShoutCast / IceCast server, defaults to icecast, this seems a sensible default in a docker environment | 
| SHOUT_OUTPUT_PORT | Connect to this port number on the specified host, defaults to 8000 | 
| SHOUT_OUTPUT_MOUNT | Mounts the MPD stream in the specified URI | 
| SHOUT_OUTPUT_USER | Sets the user name for submitting the stream to the server, defaults to source | 
| SHOUT_OUTPUT_PASSWORD | Sets the password for submitting the stream to the server, defaults to hackme | 
| SHOUT_OUTPUT_PUBLIC | Specifies whether the stream should be "public", defaults to no | 
| SHOUT_OUTPUT_MIXER_TYPE | Set to softwareif you want to be able to change the volume of the output stream | 
| SHOUT_OUTPUT_ALWAYS_ON | If set to yes, then MPD attempts to keep this audio output always open. This may be useful for streaming servers, when you don’t want to disconnect all listeners even when playback is accidentally stopped. Defaults toyes | 
Additional null outputs can be configured using the following variables:
| VARIABLE | DESCRIPTION | 
|---|---|
| NULL_OUTPUT_CREATE | Set to yesif you want to create an additional null output | 
| NULL_OUTPUT_ENABLED | Sets the output as enabled if set to yes, otherwise mpd's default behavior applies | 
| NULL_OUTPUT_NAME | The name of the Null output, defaults to null | 
| NULL_OUTPUT_SYNC | Sync mode for the nulloutput, can beyes(default) orno | 
| NULL_OUTPUT_MIXER_TYPE | Set to softwareif you want to be able to change the volume of the output stream | 
Refer to the MPD documentation for the meaning of the variables.
Additional snapcast outputs can be configured using the following variables:
| VARIABLE | DESCRIPTION | 
|---|---|
| SNAPCAST_OUTPUT_CREATE | Set to yesif you want to create an additional Snapcast output | 
| SNAPCAST_OUTPUT_ENABLED | Sets the output as enabled if set to yes, otherwise mpd's default behavior applies | 
| SNAPCAST_OUTPUT_NAME | The name of the Snapcast output, defaults to snapcast | 
| SNAPCAST_OUTPUT_FORMAT | Snapcast audio format | 
| SNAPCAST_OUTPUT_MIXER_TYPE | Snapcast mixer type, defaults to software | 
| SNAPCAST_OUTPUT_PORT | Binds the Snapcast server to the specified port, defaults to 1704 | 
| SNAPCAST_OUTPUT_BIND_TO_ADDRESS | Binds the Snapcast server to the specified address | 
| SNAPCAST_OUTPUT_ZEROCONF | Publish the Snapcast server, default is yes. | 
Refer to the MPD documentation for the meaning of the variables.
Additional snapcast outputs can be configured using the following variables:
| VARIABLE | DESCRIPTION | 
|---|---|
| FIFO_OUTPUT_CREATE | Set to yesif you want to create an additional Fifo output | 
| FIFO_OUTPUT_ENABLED | Sets the output as enabled if set to yes, otherwise mpd's default behavior applies | 
| FIFO_OUTPUT_NAME | The name of the Fifo output, defaults to fifo | 
| FIFO_OUTPUT_FORMAT | Fifo audio format | 
| FIFO_OUTPUT_MIXER_TYPE | Fifo mixer type, defaults to software | 
| FIFO_OUTPUT_PATH | Path of the fifo file | 
Refer to the MPD documentation for the meaning of the variables.
See some usage examples here.
If at least one set of credentials for Last.fm, Libre.fm or Jamendo are provided, mpdscribble will be started and it will scrobble the songs you play.
You can provide credential using the environment variables or using credential files stored in the volume /user/config.
The relevant files are:
- lastfm.txt
- librefm.txt
- jamendo.txt
When using a desktop system with PulseAudio, running a docker-compose with a restart=unless-stopped is likely to cause issues to the entire PulseAudio. At least that is what is systematically happening to me on my desktop systems.
You might want to create a user-level systemd unit. In order to do that, move to the pulse directory of this repo, then run the following to install the service:
./install.sh
After that, the service can be controlled using ./start.sh, ./stop.sh, ./restart.sh.
You can completely uninstall the service by running:
./uninstall.sh
Please find documentation here.
See this document.
See this document.