Manutenzione Cloud Dispensa
Preliminari
Verificare la versione a cui siamo: https://scan.nextcloud.com/results/50ee0a1d-6f8e-4aa4-886a-5d7676f0cbeb
Se c’è scritto: NOT on latest patch level
Significa che dobbiamo aggiornare.
Verificare le versioni successive di nexcloud:
Esempio: da scan vediamo che stiamo usando la versione: 24.0.6.1
Verfichiamo qual’è l’ultima versione della nostra “maior release”, ovvero il primo numero a sinistra: esempio: 24.0.8
Qui: https://hub.docker.com/_/nextcloud o qui: https://nextcloud.com/it/changelog/ o qui: https://download.nextcloud.com/server/releases/
Esempio, dalla 24.0.6 aggiorneremo alla 24.0.8, verificheremo gli aggiornamenti del database via web:
e poi procederemo ad aggiornare alla 25.0.1, verificheremo di nuovo gli aggiornamenti degl indici del database e poi faremo l’ultimo salto di versione a quella disponibile, esempio: 25.0.2
Procedere con l’autenticarsi sul server
Backup
Fonte: https://docs.nextcloud.com/server/20/admin_manual/maintenance/backup.html
Per fare il backup di una installazione Nextcloud ci sono 4 cose principali che devi mantenere:
The config folder
The data folder
The theme folder
The database
Eseguire prima il test di salute dell’installazione.
A questo punto recarsi nella cartella dove abbiamo il file docker-compose.yml
cd /opt/nextcloud/
Quindi da lì impostare la modalità manutenzione:
docker exec -u www-data nextcloud-app php occ maintenance:mode --on
Verificare che abbia funzionato: https://campiaperti.tetaneutral.net/login
Fare il backup di config, data, themes, e custom-apps, che si trovano tutte dentro la cartella app/
#tar -czvf /home/backup_dispensa/data-nextcloud_$(date +%Y%m%d%H%M).tar.gz /opt/nextcloud/app
fare il backup del db:
docker exec -i nextcloud-mariadb mysqldump --single-transaction -u [username] -p [db_name] > /home/backup_dispensa/nextcloud-sqlbkp_$(date +%Y%m%d%H%M).bak
Ti chiederà la password del db, la trovi leggendo nel file docker-compose.yml
Cancellare i backup più vecchi.
Copiare in locale il backup
Dal proprio PC, quindi in un altro terminale rispetto a quello in cui si è connessi al server, scaricare il backup del db. Il nome del backup, es: nextcloud-sqlbkp_202301101834.bak è da andare a leggere nella cartella dei backup e da sostituire nel seguente comando:
scp -P 2222 -r root@campiaperti.tetaneutral.net:/home/backup_dispensa/nextcloud-sqlbkp_DATA.bak /home/$USER/
Scaricare il backup della directory app, che contiene (config, data, themes e custom-apps)
scp -P 2222 -r root@campiaperti.tetaneutral.net:/home/backup_dispensa/nextcloud-app_DATA.tar.gz /home/$USER/
Se non si riesce a scaricare il backup dei dati perchè la banda di connessione o il tempo a disposizione è poco, scaricare assolutamente almeno il backup del database.
Aggiornare
Modificato il docker-compose.yml con l’immagine successiva nextcloud: esempio 24.0.8
docker-compose down
docker-compose up -d
docker-compose exec --user www-data app php occ maintenance:mode --off
Poi da loggate come Admin in grafica web, visitando questa pagina appuriamo che mancavano degli aggiornamenti al db, allora glieli abbiamo fatti:
docker-compose exec --user www-data app php occ db:add-missing-indices
TEST: https://campiaperti.tetaneutral.net, funziona!
finito! C’è da aggiornare la pagina di copertina del cloud per dare feedback all’ufficio che abbiamo aggiornato!
Se c’è tempo è cosa carina mettere ordine tra le immagini docker che possono essere rimaste lì da tempo.
Verificare che siamo all’ultima versione: https://scan.nextcloud.com/results/50ee0a1d-6f8e-4aa4-886a-5d7676f0cbeb Il risultato dovrebbe essere A+
Ripristinare configurazione di ngnix “client_max_body_size”
docker exec -ti nextcloud-proxy /bin/bash
da dentro al container
vi /etc/nginx/nginx.conf
aggiungere la riga dentro a http {…}
client_max_body_size 20M;
riavviare ad nginx
nginx -s reload
Togliere la modalità manutenzione
docker exec -u www-data nextcloud-app php occ maintenance:mode --off