MasterpieceDockerCompose/unifi/README.md

100 lines
2.9 KiB
Markdown
Raw Normal View History

2021-05-25 11:36:01 +02:00
# Unifi Controller
2021-05-21 12:55:29 +02:00
<div align="center">
<img src="https://i.ibb.co/6srMcZx/Screenshot-2021-05-21-Uni-Fi.png" />
</div>
2021-05-25 11:36:01 +02:00
## Descrizione
[Sito ufficiale](https://www.ui.com/software/) - [Repo (Github)](https://github.com/linuxserver/docker-unifi-controller) - [Demo](https://demo.ui.com) - [Docs](https://dl.ui.com/guides/UniFi/UniFi_Controller_V5_UG.pdf)
2021-05-21 12:55:29 +02:00
Unfi Controller è un controller per la gestione dell'hardware Ubiquiti:
- Gestione di tutto solo tramite interfaccia web
- Aggiornare, configurare e personalizzare tutto l'hardware compatibile
- Backup della configurazione, sia del controller che dell'hardware
2021-05-21 12:55:29 +02:00
2021-05-25 11:36:01 +02:00
## Struttura file e cartelle
2021-05-21 12:55:29 +02:00
```
/home/
└── docker/
└── unifi/
├── config/
├── .env
└── docker-compose.yml
2021-05-21 12:55:29 +02:00
```
* `config/` - cartella dove risiedono i dati che servono a unifi
* `.env` - file contenenti le variabili environment per il docker-compose
2021-05-21 12:55:29 +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-21 12:55:29 +02:00
2021-05-25 11:36:01 +02:00
## Esempi
Semplice esempio per iniziare ad usare subito il container
2021-05-21 12:55:29 +02:00
2021-05-25 11:36:01 +02:00
### docker-compose
2021-05-21 12:55:29 +02:00
`docker-compose.yml`
```yml
version: "3.5"
2021-05-21 12:55:29 +02:00
services:
unifi:
container_name: linuxserver-unifi
image: ghcr.io/linuxserver/unifi-controller
security_opt:
- no-new-privileges:true
networks:
- custom-bridge
2021-05-21 12:55:29 +02:00
restart: unless-stopped
ports:
- ${UNIFI_STUN_PORT:-3478}:3478/udp
2021-05-21 12:55:29 +02:00
- ${UNIFI_WEBUI_PORT:-8080}:8080
- ${UNIFI_HTTPS_PORT:-8443}:8443
- ${UNIFI_AP_DSV_PORT:-10001}:10001/udp
2021-05-21 12:55:29 +02:00
env_file: .env
volumes:
- ${UNIFI_CONFIG:-/home/docker/unifi/config}:/config
networks:
custom-bridge:
name: custom-bridge
driver: bridge
2021-05-21 12:55:29 +02:00
```
`.env`
```bash
# Generale
UNIFI_STUN_PORT=3478
2021-05-21 12:55:29 +02:00
UNIFI_WEBUI_PORT=8080
UNIFI_HTTPS_PORT=8443
UNIFI_AP_DSV_PORT=10001
UNIFI_CONFIG=/config
# Unifi
2021-05-25 11:36:01 +02:00
MEM_LIMIT=1024M # opzionale, di base è un 1 GB di ram massima allocata
2021-05-21 12:55:29 +02:00
```
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-21 12:55:29 +02:00
2021-05-25 11:36:01 +02:00
## Aggiornamento
### Automatico
Se usate [watchtower](../watchtower) il container si aggiorna automaticamente
2021-05-21 12:55:29 +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-21 12:55:29 +02:00
2021-05-25 11:36:01 +02:00
## Backup e ripristino
### Backup
Usado [borg](../borg_backup) per fare i backup giornalieri dell'intera cartella `unifi`
2021-05-21 12:55:29 +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 `unifi`
3. dal backup copiare la cartella `unifi`
4. far ripartire il container `docker-compose up -d`
2021-05-21 12:55:29 +02:00
2021-05-25 11:36:01 +02:00
## Todo
2021-05-21 12:55:29 +02:00
Implementare:
2021-05-25 11:36:01 +02:00
- reverse proxy: **[caddy](https://caddyserver.com/)** o **[traefik](https://doc.traefik.io/traefik/)**