Servizi self-hosted
Nextcloud
Comandi Docker per Nextcloud (occ)
Premessa I comandi
occvanno sempre eseguiti come utentewww-data. SostituisciCONTAINERcon il nome del tuo container Nextcloud (lo trovi condocker ps).
occ — comando base
docker exec -u www-data CONTAINER php occ <comando>
docker exec -u www-data CONTAINER php occ list # elenco di TUTTI i comandi
Manutenzione
# Modalità manutenzione (attiva prima di interventi pesanti / backup)
docker exec -u www-data CONTAINER php occ maintenance:mode --on
docker exec -u www-data CONTAINER php occ maintenance:mode --off
# Riparazioni dopo aggiornamenti o problemi
docker exec -u www-data CONTAINER php occ maintenance:repair
# Stato generale dell'installazione
docker exec -u www-data CONTAINER php occ status
File (ripristino da snapshot / backup)
Quando si ripristinano file direttamente sul filesystem, Nextcloud non li "vede" finché non si rilancia la scansione che risincronizza il database con il disco.
docker exec -u www-data CONTAINER php occ files:scan --all
docker exec -u www-data CONTAINER php occ files:scan UTENTE
docker exec -u www-data CONTAINER php occ files:scan --path="/UTENTE/files/Cartella"
docker exec -u www-data CONTAINER php occ files:cleanup # rimuove voci orfane dal DB
Nota: il
--pathparte sempre da/utente/files/..., non dal percorso assoluto sul disco. I file ripristinati devono trovarsi nel volume dati montato nel container (di solito/var/www/html/data) e appartenere awww-data.
Correggere il proprietario dei file ripristinati
docker exec -u www-data CONTAINER find /var/www/html/data/UTENTE/files/Cartella -exec chown www-data:www-data {} \;
Utenti
docker exec -u www-data CONTAINER php occ user:list
docker exec -u www-data CONTAINER php occ user:add NOMEUTENTE
docker exec -u www-data CONTAINER php occ user:resetpassword NOMEUTENTE
docker exec -u www-data CONTAINER php occ user:setting NOMEUTENTE files quota 10GB
App
docker exec -u www-data CONTAINER php occ app:list
docker exec -u www-data CONTAINER php occ app:enable NOMEAPP
docker exec -u www-data CONTAINER php occ app:disable NOMEAPP
docker exec -u www-data CONTAINER php occ app:update --all
Configurazione e indici database
# Leggi/scrivi parametri di config.php
docker exec -u www-data CONTAINER php occ config:list system
docker exec -u www-data CONTAINER php occ config:system:set key --value="valore"
# Indici e colonne mancanti (warning tipici nella pagina "Panoramica")
docker exec -u www-data CONTAINER php occ db:add-missing-indices
docker exec -u www-data CONTAINER php occ db:add-missing-columns
docker exec -u www-data CONTAINER php occ db:convert-filecache-bigint
Cron / anteprime
docker exec -u www-data CONTAINER php occ background:cron # imposta cron come metodo job
docker exec -u www-data CONTAINER php occ preview:generate-all # rigenera anteprime
Suggerimento: alias per scrivere meno
Crea un alias nella shell dell'host per non riscrivere ogni volta la parte lunga:
alias nocc='docker exec -u www-data CONTAINER php occ'
Poi basta scrivere, ad esempio:
nocc files:scan --all
nocc status
Se usi docker compose, l'equivalente del comando base è:
docker compose exec -u www-data app php occ <comando>(sostituisci
appcon il nome del servizio Nextcloud nel tuodocker-compose.yml).
Immich
Comandi Docker per Immich
I container principali di Immich sono
immich_server,immich_machine_learningeimmich_postgres. Tutti i comandi si eseguono dalla cartella dove si trova ildocker-compose.yml.
immich-admin — CLI amministrativa
Il container immich_server include una CLI integrata chiamata immich-admin.
Prima connettiti al container, poi esegui i comandi:
docker exec -it immich_server bash
# una volta dentro:
immich-admin help
Oppure direttamente senza entrare nel container:
docker exec -it immich_server immich-admin <comando>
| Comando | Descrizione |
|---|---|
help |
Mostra tutti i comandi disponibili |
version |
Versione installata di Immich |
list-users |
Elenca gli utenti |
reset-admin-password |
Resetta la password dell'admin |
enable-password-login |
Abilita il login con password |
disable-password-login |
Disabilita il login con password |
enable-oauth-login |
Abilita il login OAuth |
disable-oauth-login |
Disabilita il login OAuth |
enable-maintenance-mode |
Attiva la modalità manutenzione |
disable-maintenance-mode |
Disattiva la modalità manutenzione |
change-media-location |
Aggiorna i path nel DB dopo aver spostato i media |
Esempi pratici
# Resettare la password dell'admin
docker exec -it immich_server immich-admin reset-admin-password
# Attivare la modalità manutenzione
docker exec -it immich_server immich-admin enable-maintenance-mode
# → restituisce un URL con token per accedere alla manutenzione
# Disattivarla dopo l'intervento
docker exec -it immich_server immich-admin disable-maintenance-mode
# Vedere la versione
docker exec -it immich_server immich-admin version
Backup del database
Il backup automatico è attivo per default (ogni giorno alle 2:00, ultimi 14 backup).
I file vengono salvati in UPLOAD_LOCATION/backups.
Per avviare un backup manuale via web UI: Administration → Job Queues → Create job → Create Database Backup
Per fare un backup manuale da riga di comando:
docker exec -t immich_postgres pg_dumpall \
--clean --if-exists \
--username=<DB_USERNAME> \
> /percorso/backup/immich-database.sql
Con compressione:
docker exec -t immich_postgres pg_dumpall \
--clean --if-exists \
--username=<DB_USERNAME> \
| gzip > /percorso/backup/immich-database.sql.gz
Attenzione: il backup del database contiene solo i metadati, non le foto/video. Per un backup completo occorre copiare anche la cartella
UPLOAD_LOCATION.
Restore del database
Il metodo raccomandato è via web UI: Administration → Maintenance → Restore database backup
Per il restore da riga di comando (richiede un'installazione fresca dove il server non ha mai girato):
# 1. Crea i container senza avviarli
docker compose create
# 2. Avvia solo Postgres
docker start immich_postgres
sleep 10
# 3. Esegui il restore
docker exec -i immich_postgres psql \
--dbname=postgres \
--username=<DB_USERNAME> \
< /percorso/backup/immich-database.sql
# 4. Avvia tutti gli altri container
docker compose up -d
Se il server è già stato avviato prima del restore, elimina la cartella
DB_DATA_LOCATIONper azzerare il database prima di procedere.
Permessi e proprietario dei file
Se hai ripristinato file direttamente sul filesystem, controlla che il proprietario sia corretto:
# Trova l'UID usato da Immich (di default 1000)
docker exec immich_server id
# Correggi il proprietario nella cartella upload
sudo chown -R 1000:1000 /percorso/UPLOAD_LOCATION