AzuraCast is a self-hosted, all-in-one web radio management suite. Using its easy installer and powerful but intuitive web interface, you can start up a fully working web radio station in a few quick minutes.
AzuraCast works for web radio stations of all types and sizes, and is built to run on even the most affordable VPS web hosts. AzuraCast's mascot is Azura Ruisselante, created by Tyson Tan.
AzuraCast is currently in beta. Many web radio stations already run AzuraCast, but keeping your server up-to-date with the latest code from the GitHub repository is strongly recommended for security, bug fixes and new feature releases. It's unlikely, but updates may result in unexpected issues or data loss, so always make sure to keep your station's media files backed up in a second location.
To install AzuraCast, you should have a basic understanding of the Linux shell terminal. Once installed, every aspect of your radio station can be managed via AzuraCast's web interface.
Want to see AzuraCast for yourself? Check out screenshots or visit our demo site at demo.azuracast.com:
- Username:
[email protected]
- Password:
demo
Follow our installation guide for instructions on how to install AzuraCast on your own server.
- Rich Media Management: Upload songs, edit metadata, preview songs and organize music into folders from your browser.
- Playlists: Add music to standard-rotation playlists (in sequential or shuffled playback order) or schedule a playlist to play at a scheduled time, or once per x songs/minutes/etc.
- Live DJs: Set up individual DJ/streamer accounts and see who's currently streaming from your station's profile page.
- Web DJ: Broadcast live directly from your browser, with no extra software needed, with AzuraCast's built-in Web DJ tool.
- Public Pages: AzuraCast includes embeddable public pages that you can integrate into your existing web page or use as the basis for your own customized player.
- Listener Requests: Let your listeners request specific songs from your playlists, both via an API and a simple public-facing listener page.
- Remote Relays: Broadcast your radio signal (including live DJs) to any remote server running Icecast or SHOUTcast.
- Web Hooks: Integrate your station with Slack, Discord, TuneIn, Twitter and more by setting up web hooks that connect to third-party services.
- Detailed Analytics and Reports: Keep track of every aspect of your station's listeners over time. View reports of each song's impact on your listener count. You can also generate a report that's compatible with SoundExchange for US web radio royalties.
- Role-based User Management: Assign global and per-station permissions to a role, then add users to those roles to control access.
- Custom Branding: Modify every aspect of both the internal and public-facing AzuraCast pages by supplying your own custom CSS and JavaScript.
- Authenticated RESTful API: Individual users in the system can create API keys which have the same permissions they have in the system. The AzuraCast API is a powerful and well-documented tool for interacting with installations.
- Web Log Viewing: Quickly diagnose problems affecting any part of the AzuraCast system through the system-wide web log viewer.
- Automatic Radio Proxies: Many users can't connect directly to radio station ports (i.e. 8000) by default, so AzuraCast includes an automatic nginx proxy that lets listeners connect via the http (80) and https (443) ports. These proxies are also compatible with services like CloudFlare.
AzuraCast will automatically retrieve and install these components for you:
- Liquidsoap as the always-playing "AutoDJ"
- Icecast 2.4 as a radio broadcasting frontend (Icecast-KH installed on supported platforms)
For x86/x64 installations, SHOUTcast 2 DNAS can also be used as a broadcasting frontend. SHOUTcast is non-free software and does not come bundled with AzuraCast, but can be installed via the administration panel after AzuraCast has been installed.
- NGINX for serving web pages and the radio proxy
- MariaDB as the primary database
- PHP 7.2 powering the web application
- InfluxDB for time-series based statistics
- Redis for sessions, database and general caching
Once installed and running, AzuraCast exposes an API that allows you to monitor and interact with your stations. Documentation about this API and its endpoints are available on the AzuraCast API Documentation.
AzuraCast is licensed under the Apache license, version 2.0. This project is free and open-source software, and pull requests are always welcome.
If you need help with AzuraCast, the first place you should visit is our Support page, which features solutions to a number of commonly encountered issues and questions, as well as instructions on how to check your server's log files for more details. If you do need our help via GitHub, supplying these logs is absolutely essential in helping us diagnose and resolve your issue.
New feature requests are powered by FeatureUpvote. You can visit our Feature Request Page to submit a new feature request or vote on existing ones.
For bug and error reports, we rely exclusively on our GitHub Issues board to diagnose, track and update these reports. First, check to make sure the issue you're experiencing isn't already reported on GitHub. If it is, you can subscribe to the existing ticket for updates on the issue's progress. If your issue or request isn't already reported, click the "New Issue" button to create it. Make sure to follow the template provided, as it asks important details that are very important to our team.
Please keep in mind that AzuraCast is a free software project built and maintained by volunteers, so there may be some delays in getting back to you. We will make the absolute best effort possible to resolve your issues and answer your questions.
We frequently post to social media any time there are significant updates to our software, security issues that users should be aware of, or upcoming changes to third-party software. You can get these updates in a more timely fashion by following our accounts:
- On Twitter at @AzuraCast, or
- On Mastodon at @[email protected]
We also have a Slack channel for developers, translators and radio station operators to help us collaborate in real time. You are welcome to join us and chat with us directly there.
Note that our social media channels aren't the best way to report issues to us; instead, you should use the GitHub issues instructions above, as this allows our whole team to help resolve and track the progress of the issue in one location.
We would like to thank the following organizations for their support of AzuraCast's ongoing development:
-
DigitalOcean for generously providing the server resources we use for our demonstration instance, our staging and testing environments, and more
-
JetBrains for making our development faster, easier and more productive with tools like PhpStorm
-
CrowdIn for giving us a simple and powerful tool to help translate our application for users around the world
-
GitKraken for providing an easy-to-use and powerful Git project management tool that our whole team can use.
-
Sentry for providing a great way to aggregate errors being reported from AzuraCast installations around the web.
-
Netlify for supporting open-source software like ours and for serving as the host of our primary azuracast.com web site.
-
The creators and maintainers of the many free and open-source tools that AzuraCast is built on, who have done so much to help move FOSS forward
AzuraCast will always be available free of charge, but if you find the software useful and would like to support the project's lead developer, visit either of the links below. Your support is greatly appreciated.