mStream is a personal music streaming server. You can use mStream to stream your music from your home computer to any device, anywhere.
- Works Cross Platform. Tested on Windows, OSX, Ubuntu, Arch, and Raspbian
- Light on memory and CPU
- Tested on multi-terabyte libraries
- Runs on ARM board like the Raspberry Pi
- Gapless Playback
- Milkdrop Visualizer
- Playlist Sharing
- Upload Files through the file explorer
- AutoDJ - Queues up random songs
- Available on Google Play
- Easily syncs music to your phone for offline playback
- Multi server support
- Coming soon to iOS
This is the easiest way to install mStream:
- Has no dependencies
- Auto boots server on startup
- Comes with GUI tools for server configuration and management
LinuxServer.io have produced a multiarch Alpine container for mStream for x86-64
, arm64
& armhf
which is rebuilt automatically with any base image package updates or new releases of mStream and features persistent database and album images, and the possibility of advanced usage by editing config.json
directly.
Simply pulling linuxserver/mstream
should retrieve the correct image for your arch, but you can also pull specific arch images or mStream releases via tags.
See the readme for details on how to get up and running using docker or docker compose on either:
- Github or
- Docker Hub
If you just want the core part of mStream without all the UI tools, you can install mStream from the NPM or Git repositories.
# Install From Git
git clone https://github.com/IrosTheBeggar/mStream.git
cd mStream
npm install
sudo npm link
# To update mStream just pull from git and reboot the server
git pull
You can also install mStream through npm with npm install -g mstream
. This is not recommended since some OSes (like Ubuntu) require sudo to do this.
You can boot mstream with the command mstream
# Boot mStream
mstream
If that doesn't work (sometimes npm link
fails on Windows), you can use the alternative command:
# Boot mStream
node cli-boot-wrapper.js
By default, mStream uses the config file save/conf/default.json
. If you want to use a different config file, boot mStream with -j
flag.
mstream -j /path/to/config.json
The docs on mStream config files
-
Dependencies: NodeJS v10 or greater
-
Supported File Formats: flac, mp3, mp4, wav, ogg, opus, aac, m4a
All the details about mStream are available in the docs folder
mStream is built on top some great open-source libraries:
- music-metadata - The best metadata parser for NodeJS
- LokiJS - A native, in-memory, database written in JavaScript. LokiJS is the reason mStream is so fast and easy to install
- Audioplayers - Cross platform audio library for Android and iOS that powers the mobile apps
- Howler - An audio library that powers the WebApp
- Butterchurn - A clone of Milkdrop Visualizer written in JavaScript
- WebAmp - A WinAmp clone that works in the browser
And thanks to the LinuxServer.io group for maintaining the Docker image!