Ga naar hoofdinhoud

Dedicated Server: Nextcloud Installatie

Deze handleiding is gemaakt met de volgende producten:

(Details kunnen verschillen bij producten van verschillende aanbieders, maar de hoofdconcepten blijven hetzelfde)

Introductie

Nextcloud is een open source cloudoplossing en een fork van Owncloud, opgericht in 2016 door de voormalige Owncloud-oprichter Frank Kalitschek.

Om optimale performance, stabiliteit en functionaliteit te garanderen, wordt de volgende setup aanbevolen voor het hosten van een Nextcloud-server. De Nextcloud-server is niet compatibel met Windows en MacOS. Tenminste niet zonder extra virtualisatie of vergelijkbare workarounds.

Voorbereiding

De volgende vereisten worden aanbevolen door de ontwikkelaars en zijn gebaseerd op onze eigen ervaring. Je kunt problemen tegenkomen als je niet aan deze voorwaarden voldoet.

Hardware

ComponentenMinimaalAanbevolen
CPU2x 1 GHz4x 2+ GHz
RAM512 MB4+ GB
Opslag10 GB50+ GB
Bandbreedte100 mbit/s (up & down)500 mbit/s (up & down) Aanbevolen als meerdere gebruikers de cloud gaan gebruiken

Software

PlatformOpties
BesturingssysteemUbuntu (14.04, 16.04, 18.04), Debian (8,9,10), CentOS 6.5/7
DatabaseMySQL of MariaDB 5.5+ (aanbevolen), SQLite (alleen voor testen en minimale installaties)
WebserverApache 2.4 met mod_php of php-fpm (aanbevolen)
PHP5.6, 7.0 (aanbevolen), 7.1 (aanbevolen), 7.2

Voorbereiding

Je moet verbinding maken via een SSH-client om de cloud op een Linux-server te installeren. Als je niet zeker weet hoe je SSH gebruikt, bekijk dan deze gids: Eerste toegang (SSH)

Zodra de verbinding staat, kun je de benodigde pakketten installeren die nodig zijn voor de daadwerkelijke Nextcloud-installatie. Dit omvat het installeren van een webserver en PHP.


Apache (Webserver)

🗄️ Debian 8/9/10:

sudo apt update && sudo apt -y upgrade
sudo apt -y install apache2

PHP (Hypertext Preprocessor)

🗄️ Debian 8:

# Stap 1: PHP 7.3 PPA repository toevoegen
sudo apt -y install lsb-release apt-transport-https ca-certificates
sudo wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg
echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/php7.3.list

# Stap 2: PHP 7.3 installeren
sudo apt -y install php7.3

# Stap 3: PHP 7.3 extensies installeren
sudo apt install php7.3-cli php7.3-fpm php7.3-json php7.3-pdo php7.3-mysql php7.3-zip php7.3-gd php7.3-mbstring php7.3-curl php7.3-xml php7.3-bcmath php7.3-json

🗄️ Debian 9:

# Stap 1: PHP 7.3 PPA repository toevoegen
sudo apt -y install lsb-release apt-transport-https ca-certificates
sudo wget -O /etc/apt/trusted.gpg.d/php.gpg https://packages.sury.org/php/apt.gpg
echo "deb https://packages.sury.org/php/ $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/php7.3.list

# Stap 2: PHP 7.3 installeren
sudo apt -y install php7.3

# Stap 3: PHP 7.3 extensies installeren
sudo apt install php7.3-cli php7.3-fpm php7.3-json php7.3-pdo php7.3-mysql php7.3-zip php7.3-gd php7.3-mbstring php7.3-curl php7.3-xml php7.3-bcmath php7.3-json

🗄️ Debian 10:

# Stap 1: PHP 7.3 installeren
sudo apt -y install php php-common

# Stap 2: PHP 7.3 extensies installeren
sudo apt -y install php-cli php-fpm php-json php-pdo php-mysql php-zip php-gd php-mbstring php-curl php-xml php-pear php-bcmath

Controleer PHP-versie voor functionaliteit

php -v

De volgende stap is het bepalen van het type database om de relevante informatie op te slaan. Er zijn verschillende opties:


Als je hebt gekozen voor dit type database, volg dan deze stappen:

Pakketinstallatie:

sudo apt-get install mariadb-server php-mysql

Tijdens de installatie wordt je gevraagd een root-wachtwoord in te stellen. Als er geen wachtwoord gevraagd wordt, is het standaardwachtwoord leeg. Dit is niet veilig en moet daarom direct aangepast worden!

De volgende stap is verbinden met de database-server en de benodigde database aanmaken:

mysql -u root -p
CREATE DATABASE nextcloud;

Vervolgens moet er een gebruiker worden aangemaakt die toegang krijgt tot de Nextcloud-database.

CREATE USER 'nc_user'@'localhost' IDENTIFIED BY 'JOUW_WACHTWOORD_HIER';
info

Sla deze stap niet over door de root-gebruiker te gebruiken. Dit is niet veilig en kan je data in gevaar brengen!

De laatste stap is het toekennen van rechten aan de nieuwe gebruiker:

GRANT ALL PRIVILEGES ON nextcloud.* TO 'nc_user'@'localhost';
FLUSH PRIVILEGES;

Als je klaar bent, druk je op Ctrl-D om de database te verlaten en verder te gaan met de volgende stappen.

Installatie

Nu kan de daadwerkelijke installatie van Nextcloud beginnen. De software moet worden gedownload en uitgepakt:

cd /var/www/
wget https://download.nextcloud.com/server/releases/latest.zip
apt-get install unzip
unzip latest.zip
chown -R www-data:www-data nextcloud
rm latest.zip

Als deze stap klaar is, is het tijd om het installatiescript te starten. Toegang is mogelijk via de browser via de volgende URL:

De configuratie van het installatiescript verschijnt, waarin een root-gebruiker wordt aangemaakt en databasegegevens worden ingevuld:

Beveiliging en veiligheid

Setup Waarschuwingen

Data Directory

Het wordt sterk aanbevolen om de data directory buiten de web root directory te plaatsen (dus buiten /var/www). De makkelijkste manier is dit direct bij een nieuwe installatie te doen. De directory kan tijdens de setup worden gedefinieerd. De directory moet echter eerst worden aangemaakt en de juiste rechten krijgen. De data kan bijvoorbeeld opgeslagen worden in een map genaamd Cloud in de home directory.

mkdir /home/cloud/
chown -R www-data:www-data /home/cloud/

HTTPS via SSL-certificaat (Let's Encrypt)

Een goede cloudoplossing is alleen toegankelijk via een SSL-verbinding. Zonder SSL-versleuteling worden data en informatie in platte tekst verstuurd. Deze info kan makkelijk en snel onderschept en gelezen worden zonder encryptie.

<IfModule mod_ssl.c>
<VirtualHost *:443>
DocumentRoot "/var/www/nextcloud"
ServerName domain.tld

ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined

<Directory /var/www/nextcloud/>
Options +FollowSymlinks
AllowOverride All

<IfModule mod_dav.c>
Dav off
</IfModule>

SetEnv HOME /var/www/nextcloud
SetEnv HTTP_HOME /var/www/nextcloud
Satisfy Any

</Directory>

SSLCertificateFile /etc/letsencrypt/live/domain.tld/fullchain.pem
SSLCertificateKeyFile /etc/letsencrypt/live/domain.tld/privkey.pem
</VirtualHost>
</IfModule>

<IfModule mod_headers.c>
Header always set Strict-Transport-Security "max-age=15768000; preload"
</IfModule>

Daarnaast moet al het HTTP-verkeer worden doorgestuurd naar HTTPS met een permanente redirect (statuscode 301). Dit kan met Apache via een configuratie zoals de volgende Apache VirtualHosts-configuratie:

<VirtualHost *:80>
ServerName domain.tld
Redirect permanent / https://domain.tld/
</VirtualHost>

Nextcloud beheren

Toegang tot Nextcloud kan via de browser, maar ook via smartphone en computer met de app. De downloadlinks vind je hier: https://nextcloud.com/install/#install-clients

Onder instellingen kun je na de setup nog meer opties aanpassen en belangrijke info bekijken zoals logs en activiteiten. Dit omvat extra beveiligingsopties (twee-factor authenticatie, encryptie, ...), designinstellingen (logo, kleur, slogan, header), toegangsinstellingen en nog veel meer.

Apps

Daarnaast is het mogelijk om extra apps te installeren naast de standaard apps. Je vindt ze via het menu-item Apps.

Met zulke Apps kun je Nextcloud verder personaliseren naar jouw wensen.