NextCloud (Docker)NextCloud (Docker)

NextCloud (Docker)

NextCloud is een open source platform voor bestandssynchronisatie en samenwerking, vergelijkbaar met diensten als Dropbox of OneDrive. In deze handleiding installeren we NextCloud op een Debian server met behulp van Docker en Docker Compose.

Informatie

Deze handleiding gaat uit van een Debian server waarop Docker en de Docker Compose plugin al zijn geïnstalleerd, zoals beschreven in het bovenliggende artikel Docker.

Benodigdheden

  • Een server met een ondersteunde Debian Linux installatie
  • Docker en Docker Compose plugin geïnstalleerd
  • Een domeinnaam
  • DNS ingesteld naar het IP-adres van de server
  • Rechten als su of sudo om opdrachten als root uit te voeren

Voorbereiding

Zorg dat het systeem up-to-date is voordat je begint.

  1. Log in met SSH.
ssh gebruiker@server
  1. Werk de pakketbron en geïnstalleerde pakketten bij.
sudo apt update && sudo apt upgrade
  1. Controleer of Docker en Docker Compose beschikbaar zijn.
docker --version
docker compose version

Mapstructuur aanmaken

We plaatsen de Docker Compose configuratie en data in /opt/nextcloud.

  1. Maak de basisstructuur aan.
sudo mkdir -p /opt/nextcloud/{db,nextcloud}
  1. Geef de huidige gebruiker toegang (optioneel, handig voor beheer).
sudo chown -R $USER:$USER /opt/nextcloud
  1. Ga naar de NextCloud map.
cd /opt/nextcloud

Docker Compose bestand maken

We gebruiken een docker-compose.yml met NextCloud en MariaDB als database.

  1. Maak het bestand docker-compose.yml.
nano docker-compose.yml
  1. Plaats de volgende configuratie in het bestand:
version: "3.9"

services:
  db:
    image: mariadb:11
    container_name: nextcloud_db
    restart: unless-stopped
    command: --transaction-isolation=READ-COMMITTED --binlog-format=ROW
    environment:
      - MYSQL_ROOT_PASSWORD=sterk-root-wachtwoord
      - MYSQL_DATABASE=nextcloud
      - MYSQL_USER=nextcloud
      - MYSQL_PASSWORD=sterk-db-wachtwoord
    volumes:
      - ./db:/var/lib/mysql

  app:
    image: nextcloud:stable
    container_name: nextcloud_app
    restart: unless-stopped
    ports:
      - "8080:80"
    depends_on:
      - db
    environment:
      - MYSQL_DATABASE=nextcloud
      - MYSQL_USER=nextcloud
      - MYSQL_PASSWORD=sterk-db-wachtwoord
      - MYSQL_HOST=db
    volumes:
      - ./nextcloud:/var/www/html

Informatie

Vervang sterk-root-wachtwoord en sterk-db-wachtwoord door sterke, unieke wachtwoorden. Bewaar deze veilig.

NextCloud containers starten

  1. Download de benodigde images en start de containers in de achtergrond.
docker compose up -d
  1. Controleer of de containers draaien.
docker ps

Je zou nu containers moeten zien met namen zoals nextcloud_app en nextcloud_db.

NextCloud installatie afronden

  1. Open een browser en ga naar:
http://server-ip:8080

of, indien je een domeinnaam en reverse proxy gebruikt:

https://voorbeeld.nl
  1. Volg de stappen van de NextCloud installatie:
    • Stel een beheerdersgebruikersnaam en wachtwoord in
    • Controleer dat de database-instellingen overeenkomen met de waarden uit docker-compose.yml

Informatie

Na afronden keert NextCloud terug naar de login-pagina en kun je inloggen met het beheerdersaccount.

Data en back-ups

Alle gegevens worden opgeslagen in:

  • Database: /opt/nextcloud/db
  • NextCloud bestanden en configuratie: /opt/nextcloud/nextcloud

Waarschuwing

Maak regelmatig back-ups van deze mappen, bij voorkeur met de containers eerst in een consistente staat (bijvoorbeeld tijdelijk stoppen)

Voer het volgende uit om een back-up te maken.

cd /opt/nextcloud
docker compose down
tar czf nextcloud-backup-$(date +%F).tar.gz db nextcloud
docker compose up -d