2021-05-25 11:36:01 +02:00
|
|
|
# Jellyfin
|
2021-05-17 16:52:55 +02:00
|
|
|
<div align="center">
|
2021-07-16 12:24:19 +02:00
|
|
|
<img src="https://wtf.roflcopter.fr/pics/pj8GteT6/fuINQ6q6.jpg" />
|
2021-05-17 16:52:55 +02:00
|
|
|
</div>
|
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
## Descrizione
|
2021-07-16 12:24:19 +02:00
|
|
|
[![Sito ufficiale](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=firefoxbrowser&style=flat&label=&message=Homepage)](https://jellyfin.org/) [![Sorgente](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=github&style=flat&label=&message=Sorgente)](https://github.com/linuxserver/docker-jellyfin) [![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/linuxserver/docker-jellyfin) [![Docs](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=readthedocs&style=flat&label=&message=Docs)](https://docs.linuxserver.io/images/docker-jellyfin/) [![Demo](https://img.shields.io/static/v1.svg?color=555555&logoColor=ffffff&logo=jekyll&style=flat&label=&message=Demo)](https://demo.jellyfin.org/ "Login: demo | Password: lasciare vuoto")
|
2021-05-17 16:52:55 +02:00
|
|
|
|
|
|
|
Jellyfin è un server per la gestione di film, serie tv e musica:
|
2021-05-31 16:35:08 +02:00
|
|
|
- Interfaccia web personalizzabile tramite [CSS](https://libredd.it/r/jellyfin/search?q=flair_name%3A%22Custom%20CSS%22&restrict_sr=on)
|
2021-06-06 11:32:56 +02:00
|
|
|
- Modifica e importazione dei metadati locali, integrati o tramite servizi esterni (IMDb, OMDb, TvDB, etc)
|
|
|
|
- Multiutente con possiblità di gestione dell'accesso alle librerie (anche singolo)
|
2021-05-17 16:52:55 +02:00
|
|
|
- [Client ufficiali (e non) multi-piattaforma](https://jellyfin.org/docs/general/clients/index.html)
|
|
|
|
- [Transcodifica hardware](https://jellyfin.org/docs/general/administration/hardware-acceleration.html)
|
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
## Struttura file e cartelle
|
2021-05-17 16:52:55 +02:00
|
|
|
```
|
|
|
|
/home/
|
2021-05-22 14:55:19 +02:00
|
|
|
└── docker/
|
|
|
|
└── jellyfin/
|
|
|
|
├── config/
|
|
|
|
├── data/
|
|
|
|
├── .env
|
|
|
|
└── docker-compose.yml
|
2021-05-17 16:52:55 +02:00
|
|
|
```
|
|
|
|
* `config/` - cartella dove risiedono i dati che servono a jellyfin
|
|
|
|
* `data/` - cartella dove vanno messi i film/serie tv/musica
|
2021-06-06 11:32:56 +02:00
|
|
|
* `.env` - file contenenti le variabili environment per il docker-compose
|
2021-05-17 16:52:55 +02:00
|
|
|
* `docker-compose.yml` - file usato per creare il container
|
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
**N.B. Tutti i file e le cartelle devono essere creati a mano.**
|
2021-05-17 16:52:55 +02:00
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
## Esempi
|
|
|
|
Semplice esempio per iniziare ad usare subito il container
|
2021-05-17 16:52:55 +02:00
|
|
|
|
2021-06-18 10:11:53 +02:00
|
|
|
### network
|
|
|
|
```bash
|
|
|
|
docker network create custom-bridge
|
|
|
|
```
|
|
|
|
oppure
|
|
|
|
```bash
|
|
|
|
podman network create custom-bridge
|
|
|
|
```
|
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
### docker-compose
|
2021-05-17 16:52:55 +02:00
|
|
|
`docker-compose.yml`
|
|
|
|
```yml
|
2021-06-03 09:54:35 +02:00
|
|
|
version: "3.5"
|
2021-05-17 16:52:55 +02:00
|
|
|
services:
|
|
|
|
jellyfin:
|
|
|
|
container_name: linuxserver-jellyfin
|
|
|
|
image: ghcr.io/linuxserver/jellyfin
|
2021-06-10 09:56:26 +02:00
|
|
|
security_opt:
|
|
|
|
- no-new-privileges:true
|
2021-06-03 09:54:35 +02:00
|
|
|
networks:
|
|
|
|
- custom-bridge
|
2021-05-17 16:52:55 +02:00
|
|
|
restart: unless-stopped
|
|
|
|
ports:
|
2021-06-14 09:09:17 +02:00
|
|
|
- ${JELLYFIN_SVC_DSC_PORT:-1900}:1900/udp # opzionale, servizio per il DLNA
|
2021-05-17 16:52:55 +02:00
|
|
|
- ${JELLYFIN_WEBUI_PORT:-8096}:8096
|
2021-06-14 09:09:17 +02:00
|
|
|
- ${JELLYFIN_CLT_DSC_PORT:-7359}:7359/udp # opzionale, servizio discovery per i client
|
2021-05-17 16:52:55 +02:00
|
|
|
env_file: .env
|
|
|
|
volumes:
|
|
|
|
- ${JELLYFIN_CONFIG:-/home/docker/jellyfin/config}:/config
|
|
|
|
- ${JELLYFIN_DATA:-/home/docker/jellyfin/data}:/data
|
|
|
|
devices:
|
2021-06-06 11:32:56 +02:00
|
|
|
- /dev/dri:/dev/dri # necessario per usare Intel VAAPI video encoding
|
2021-06-03 09:54:35 +02:00
|
|
|
|
|
|
|
networks:
|
|
|
|
custom-bridge:
|
|
|
|
name: custom-bridge
|
|
|
|
driver: bridge
|
2021-05-17 16:52:55 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
`.env`
|
|
|
|
```bash
|
|
|
|
# Generale
|
2021-06-14 09:09:17 +02:00
|
|
|
JELLYFIN_SVC_DSC_PORT=1900
|
2021-05-17 16:52:55 +02:00
|
|
|
JELLYFIN_WEBUI_PORT=8096
|
|
|
|
JELLYFIN_CLT_DSC_PORT=7359
|
|
|
|
JELLYFIN_CONFIG=/config
|
|
|
|
JELLYFIN_DATA=/data
|
|
|
|
|
|
|
|
# Jellyfin
|
|
|
|
TZ=Europe/Amsterdam
|
|
|
|
# ATTIVARE IN BASE AL PROPRIO HARDWARE E NON ATTIVARE ENTRAMBI, in quanto ne basta uno solo
|
2021-06-14 09:09:17 +02:00
|
|
|
#DOCKER_MODS=linuxserver/mods:jellyfin-amd # necessario per usare GPU AMD (anche quelle integrate nella CPU)
|
2021-05-17 16:52:55 +02:00
|
|
|
#DOCKER_MODS=linuxserver/mods:jellyfin-opencl-intel # necessario per usare OpenCL-Intel
|
|
|
|
```
|
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
## Reverse proxy
|
|
|
|
Ancora non ho previsto l'uso di un reverse proxy (Vedi [Todo](#Todo))
|
2021-05-17 16:52:55 +02:00
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
## Aggiornamento
|
|
|
|
### Automatico
|
|
|
|
Usando [watchtower](../watchtower) il container si aggiorna automaticamente
|
2021-05-17 16:52:55 +02:00
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
### Manuale
|
|
|
|
1. `docker-compose pull`
|
|
|
|
2. `docker-compose up -d`
|
|
|
|
3. `docker image prune`
|
2021-05-17 16:52:55 +02:00
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
## Backup e ripristino
|
|
|
|
### Backup
|
|
|
|
Usate [borg](../borg_backup) per fare i backup giornalieri dell'intera cartella `jellyfin`
|
2021-05-17 16:52:55 +02:00
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
### Ripristino
|
|
|
|
Per una maggiore spiegazione sui passaggi da fare, controllate [qua](../borg_backup#user-content-controllare-la-cartella-dei-backup)
|
|
|
|
1. fermare il container `docker-compose down`
|
|
|
|
2. cancellare l'intera cartella `jellyfin`
|
|
|
|
3. dal backup copiare la cartella `jellyfin`
|
|
|
|
4. far ripartire il container `docker-compose up -d`
|
2021-05-17 16:52:55 +02:00
|
|
|
|
2021-05-25 11:36:01 +02:00
|
|
|
## Todo
|
2021-05-17 16:52:55 +02:00
|
|
|
Implementare:
|
2021-05-25 11:36:01 +02:00
|
|
|
- reverse proxy: **[caddy](https://caddyserver.com/)** o **[traefik](https://doc.traefik.io/traefik/)**
|