MasterpieceDockerCompose/navidrome/README.md

134 lines
3.9 KiB
Markdown
Raw Normal View History

# Navidrome
2021-11-12 15:57:16 +01:00
2021-05-15 16:54:37 +02:00
<div align="center">
<img src="https://raw.githubusercontent.com/navidrome/navidrome/master/.github/screenshots/ss-desktop-player.png" />
</div>
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
## Descrizione
2021-11-12 15:57:16 +01:00
[![Sito ufficiale](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=firefoxbrowser&style=flat&label=&message=Homepage)](https://www.navidrome.org/) [![Sorgente](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=github&style=flat&label=&message=Sorgente)](https://github.com/navidrome/navidrome) [![Docker Hub](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=docker&style=flat&label=&message=Docker Hub)](https://hub.docker.com/r/deluan/navidrome) [![Docs](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=readthedocs&style=flat&label=&message=Docs)](https://www.navidrome.org/docs/) [![Demo](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=jekyll&style=flat&label=&message=Demo)](https://demo.navidrome.org/ "Login: demo | Password: demo") ![RPI Friendly](<https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=raspberrypi&style=flat&label=&message=RPi Friendly>)
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
Navidrome è un server per la gestione e lo streaming di file musicali:
2021-11-12 15:57:16 +01:00
2021-05-15 13:15:03 +02:00
- Interfaccia web multilingua, tematizzabile, moderna e reattiva basata su Material UI
2021-05-25 11:36:01 +02:00
- Gestione multiutente, ogni utente ha le proprie playlist, preferiti, ecc...
2021-05-15 13:15:03 +02:00
- Supporto alla transcodifica on-the-fly (anche Opus) e può essere impostato per singolo utente
- Compatibile con tutti i client Subsonic/Madsonic/Airsonic
2021-05-25 11:36:01 +02:00
## Struttura file e cartelle
2021-11-12 15:57:16 +01:00
2021-05-15 13:15:03 +02:00
```
/home/
└── docker/
└── navidrome/
├── data/
├── music/
├── .env
└── docker-compose.yml
2021-05-15 13:15:03 +02:00
```
2021-11-12 15:57:16 +01:00
- `data/` - cartella dove risiedono i dati che servono a navidrome
- `music/` - cartella dove vanno messi i vostri file musicali (mp3, flac, etc)
- `.env` - file contenenti le variabili environment per il docker-compose
- `docker-compose.yml` - file usato per creare il container
2021-05-15 13:15:03 +02:00
2021-11-22 10:23:03 +01:00
**N.B. Tutti i file e le cartelle devono essere creati a mano**
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
## Esempi
2021-11-12 15:57:16 +01:00
2021-05-25 11:36:01 +02:00
Semplice esempio per iniziare ad usare subito il container
2021-05-15 13:15:03 +02:00
### network
2021-11-12 15:57:16 +01:00
2022-02-21 09:44:18 +01:00
Con docker
2021-11-12 15:57:16 +01:00
```bash
docker network create custom-bridge
```
2022-02-21 09:44:18 +01:00
oppure usando podman
2021-11-12 15:57:16 +01:00
```bash
podman network create custom-bridge
```
2021-05-25 11:36:01 +02:00
### docker-compose
2021-11-12 15:57:16 +01:00
2021-05-15 13:15:03 +02:00
`docker-compose.yml`
2021-11-12 15:57:16 +01:00
2021-05-15 13:15:03 +02:00
```yml
version: "3"
services:
navidrome:
container_name: navidrome
image: deluan/navidrome
security_opt:
- no-new-privileges:true
2021-11-12 15:57:16 +01:00
networks:
- custom-bridge
2021-05-15 13:15:03 +02:00
restart: unless-stopped
ports:
2021-05-17 12:45:18 +02:00
- ${NAVIDROME_WEBUI_PORT:-4533}:4533
env_file: .env
2021-05-15 13:15:03 +02:00
volumes:
- ${NAVIDROME_DATA:-/home/docker/navidrome/data}:/data
- ${MUSIC_DIR:-/home/music}:/music:ro
networks:
custom-bridge:
name: custom-bridge
driver: bridge
2021-05-15 13:15:03 +02:00
```
`.env`
2021-11-12 15:57:16 +01:00
2021-05-15 13:15:03 +02:00
```bash
# Generale
2021-05-17 12:45:18 +02:00
NAVIDROME_WEBUI_PORT=4533
2021-05-17 11:57:31 +02:00
NAVIDROME_DATA=/home/docker/navidrome/data
2021-05-15 13:15:03 +02:00
MUSIC_DIR=/home/music
# Navidrome
ND_LOGLEVEL=info
2021-05-15 13:15:03 +02:00
```
2021-05-25 11:36:01 +02:00
## Reverse proxy
2021-11-12 15:57:16 +01:00
Vedi [Todo](#Todo)
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
## Aggiornamento
2021-11-12 15:57:16 +01:00
2021-05-25 11:36:01 +02:00
### Automatico
2021-11-12 15:57:16 +01:00
2021-05-25 11:36:01 +02:00
Usando [watchtower](../watchtower) il container si aggiorna automaticamente
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
### Manuale
2021-11-12 15:57:16 +01:00
1. `docker-compose up -d`
2. `docker image prune`
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
## Backup e ripristino
2021-11-12 15:57:16 +01:00
2021-05-25 11:36:01 +02:00
### Backup
2021-11-12 15:57:16 +01:00
Usate [borg](../borg) per fare i backup giornalieri dell'intera cartella `navidrome`
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
### Ripristino
2021-11-12 15:57:16 +01:00
Per una maggiore spiegazione sui passaggi da fare, controllate [qua](../borg#user-content-controllare-la-cartella-dei-backup)
2021-11-12 15:57:16 +01:00
2022-02-21 09:44:18 +01:00
1. fermare il container con `docker-compose down`
2021-05-25 11:36:01 +02:00
2. cancellare l'intera cartella `navidrome`
3. dal backup copiare la cartella `navidrome`
2022-02-21 09:44:18 +01:00
4. far ripartire il container con `docker-compose up -d`
2021-05-15 13:15:03 +02:00
2021-05-25 11:36:01 +02:00
## Todo
2021-11-12 15:57:16 +01:00
2021-05-15 13:15:03 +02:00
Implementare:
2021-11-12 15:57:16 +01:00
2021-05-25 11:36:01 +02:00
- reverse proxy: **[caddy](https://caddyserver.com/)** o **[traefik](https://doc.traefik.io/traefik/)**
---
2021-11-12 15:57:16 +01:00
Licenza: [CC BY-SA 4.0](https://creativecommons.org/licenses/by-sa/4.0/legalcode.txt)