134 lines
3.6 KiB
Markdown
134 lines
3.6 KiB
Markdown
---
|
|
title: Install using docker
|
|
sidebar_position: 10
|
|
---
|
|
|
|
import Tabs from '@theme/Tabs';
|
|
import TabItem from '@theme/TabItem';
|
|
import CodeBlock from '@theme/CodeBlock';
|
|
import vars from '@site/vars';
|
|
|
|
This guide walk you though the steps required to install LibreTime on your system using docker.
|
|
|
|
## Before installing
|
|
|
|
Before installing LibreTime, you need to make sure that [Docker](https://docs.docker.com/engine/) is installed on your operating system and **up-to-date**.
|
|
|
|
## Download
|
|
|
|
First, set the version you want to install:
|
|
|
|
<CodeBlock language="bash">
|
|
echo LIBRETIME_VERSION="{vars.version}" > .env
|
|
</CodeBlock>
|
|
|
|
Download the docker compose files from the repository:
|
|
|
|
```bash
|
|
# Load LIBRETIME_VERSION variable
|
|
source .env
|
|
|
|
wget "https://raw.githubusercontent.com/libretime/libretime/$LIBRETIME_VERSION/docker-compose.yml"
|
|
wget "https://raw.githubusercontent.com/libretime/libretime/$LIBRETIME_VERSION/docker/nginx.conf"
|
|
wget "https://raw.githubusercontent.com/libretime/libretime/$LIBRETIME_VERSION/docker/config.template.yml"
|
|
```
|
|
|
|
:::info
|
|
|
|
The `config.template.yml` configuration file you downloaded already contains specific values required by the container setup, you shouldn't change them:
|
|
|
|
```yaml
|
|
database:
|
|
host: "postgres"
|
|
password: ${POSTGRES_PASSWORD} # The value will be substituted
|
|
rabbitmq:
|
|
host: "rabbitmq"
|
|
password: ${RABBITMQ_DEFAULT_PASS} # The value will be substituted
|
|
playout:
|
|
liquidsoap_host: "liquidsoap"
|
|
liquidsoap:
|
|
server_listen_address: "0.0.0.0"
|
|
stream:
|
|
outputs:
|
|
.default_icecast_output:
|
|
host: "icecast"
|
|
source_password: ${ICECAST_SOURCE_PASSWORD} # The value will be substituted
|
|
admin_password: ${ICECAST_ADMIN_PASSWORD} # The value will be substituted
|
|
```
|
|
|
|
:::
|
|
|
|
## Setup LibreTime
|
|
|
|
Once the files are downloaded, generate a set of random passwords for the different docker services used by LibreTime:
|
|
|
|
```bash
|
|
echo "# Postgres
|
|
POSTGRES_PASSWORD=$(openssl rand -hex 16)
|
|
|
|
# RabbitMQ
|
|
RABBITMQ_DEFAULT_PASS=$(openssl rand -hex 16)
|
|
|
|
# Icecast
|
|
ICECAST_SOURCE_PASSWORD=$(openssl rand -hex 16)
|
|
ICECAST_ADMIN_PASSWORD=$(openssl rand -hex 16)
|
|
ICECAST_RELAY_PASSWORD=$(openssl rand -hex 16)" >> .env
|
|
```
|
|
|
|
Generate a [configuration file](../configuration.md) from the `./config.template.yml` template with the previously generated passwords:
|
|
|
|
```bash
|
|
bash -a -c "source .env; envsubst < config.template.yml > config.yml"
|
|
```
|
|
|
|
:::note
|
|
|
|
On Debian based systems, if the `envsubst` command isn't found you can install it with:
|
|
|
|
```bash
|
|
sudo apt install gettext-base
|
|
```
|
|
|
|
:::
|
|
|
|
Next, edit the [configuration file](../configuration.md) at `./config.yml` to fill required information and to match your needs.
|
|
|
|
:::info
|
|
|
|
You can find more details in the `docker-compose.yml` file or on the external services docker specific documentation:
|
|
|
|
- [Postgres](https://hub.docker.com/_/postgres)
|
|
- [RabbitMQ](https://hub.docker.com/_/rabbitmq)
|
|
- [Icecast](https://github.com/libretime/icecast-docker#readme)
|
|
|
|
:::
|
|
|
|
Next, run the following commands to setup the database:
|
|
|
|
```bash
|
|
docker compose run --rm api libretime-api migrate
|
|
```
|
|
|
|
Finally, start the services, and check that they're running using the following commands:
|
|
|
|
```bash
|
|
docker compose up -d
|
|
|
|
docker compose ps
|
|
docker compose logs -f
|
|
```
|
|
|
|
## Securing LibreTime
|
|
|
|
Once LibreTime is running, it's recommended to [install a reverse proxy](./reverse-proxy.md) to setup SSL termination and secure your installation.
|
|
|
|
## First login
|
|
|
|
Once the setup is completed, log in the interface (with the default user `admin` and password `admin`), and edit the project settings (go to **Settings** > **General**) to match your needs.
|
|
|
|
:::warning
|
|
|
|
Remember to change your password.
|
|
|
|
:::
|