Wie man Matomo Web Analytics unter Debian 9 installiert
Matomo (früherPiwik)ist einkostenlosundOpen-SourceWeb-AnalyticsAnwendung, die von einem Team internationaler Entwickler entwickelt wurde, die auf einemPHP/MySQLWebserver. Es verfolgt onlineBesuchean einen oder mehrereWebseitenund zeigt Berichte über diese Besuche zur Analyse an. Sie können es sich als Alternative zu Google Analytics vorstellen. Matomo ist Open Source und sein Code ist auf Github öffentlich zugänglich. Einige der Funktionen, die es hat, sind:A/B-Tests, Heatmaps, Trichter, Tracking und Reporting API, Google AdWords, Facebook-Anzeigen, Bing-Anzeigen, Cost Per Click (CPC), etc. Dieses Tutorial zeigt Ihnen, wie Sie Matomo auf einem Debian 9 (Stretch)-System mit Nginx als Webserver installieren, und wir sichern die Website mit einem Let’s Encrypt SSL-Zertifikat.
Anforderungen
Um Matomo (Piwik) auf Ihrem Debian-System laufen zu lassen, benötigen Sie ein paar Dinge:
- Webserver wie Apache oder Nginx.
- PHP Version 5.5.9 oder höher mit pdo und pdo_mysql oder mysqli, gd, xml, curl und mbsting Erweiterungen. PHP 7+ wird empfohlen.
- MySQL Version 5.5 oder höher oder die entsprechende MariaDB-Version. MySQL 5.7+ wird empfohlen.
Voraussetzungen
- Ein Betriebssystem unter Debian 9 (stretch).
- Ein Nicht-Root-Benutzer mit sudo-Rechten.
Erste Schritte
Überprüfen Sie Ihre Debian-Version:
lsb_release -ds
# Debian GNU/Linux 9.6 (stretch)
Richten Sie die Zeitzone ein:
dpkg-reconfigure tzdata
Aktualisieren Sie Ihre Betriebssystempakete (Software). Dies ist ein wichtiger erster Schritt, denn es stellt sicher, dass Sie die neuesten Updates und Sicherheitsfixes für die Standardsoftwarepakete Ihres Betriebssystems erhalten:
apt update && apt upgrade -y
Installieren Sie einige wichtige Pakete, die für die grundlegende Verwaltung des Debian-Betriebssystems notwendig sind:
apt install -y curl wget vim git unzip socat sudo
Schritt 1 – MySQL installieren und eine Datenbank für Matomo erstellen
Matomo unterstützt MySQL- und MariaDB-Datenbanken und das Debian-Team hat MySQL durch MariaDB als Standarddatenbank von Debian 9 (stretch) ersetzt, daher werden wir in diesem Tutorial MariaDB als Datenbankserver verwenden. Wenn Sie Original-MySQL installieren möchten, können Sie das offizielle MySQL-Repository von Oracle hinzufügen und verwenden.
Installieren Sie den MariaDB-Datenbankserver:
sudo apt install -y mariadb-server
Überprüfen Sie die MariaDB-Version:
mysql --version
# mysql Ver 14.14 Distrib 5.7.24, for Linux (x86_64) using EditLine wrapper
Laufenmysql_secure installation
Skript zur Verbesserung der MariaDB-Sicherheit und zur Festlegung des Passworts für MariaDBroot
Benutzer:
sudo mysql_secure_installation
Beantworten Sie jede der Fragen:
Enter current password for root (enter for none): Press Enter
Set root password? [Y/n] y
New password: your_secure_password
Re-enter new password: your_secure_password
Remove anonymous users? [Y/n] Y
Disallow root login remotely? [Y/n] Y
Remove test database and access to it? [Y/n] Y
Reload privilege tables now? [Y/n] Y
Verbinden Sie sich mit der MariaDB-Shell als Root-Benutzer:
sudo mysql -u root -p
# Enter password
Erstellen Sie eine leere MariaDB-Datenbank und einen leeren Benutzer für Matomo und merken Sie sich die Zugangsdaten:
mysql> CREATE DATABASE dbname;
mysql> GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
mysql> FLUSH PRIVILEGES;
Verlassen Sie MariaDB:
mysql> exit
Ersetzen Sie,dbname
undusername
durch Ihre eigenenpassword
Namen.
Schritt 2 – Installieren Sie PHP und die notwendigen PHP-Erweiterungen.
Installieren Sie PHP sowie die notwendigen PHP-Erweiterungen:
sudo apt install -y php7.0 php7.0-cli php7.0-fpm php7.0-common php7.0-curl php7.0-gd php7.0-xml php7.0-mbstring php7.0-mysql
Überprüfen Sie die PHP-Version:
php --version
# PHP 7.0.33-0+deb9u1 (cli) (built: Dec 7 2018 11:36:49) ( NTS )
# Copyright (c) 1997-2017 The PHP Group
# Zend Engine v3.0.0, Copyright (c) 1998-2017 Zend Technologies
# with Zend OPcache v7.0.33-0+deb9u1, Copyright (c) 1999-2017, by Zend Technologies
Der PHP-FPM-Dienst wird beim Neustart auf dem Debian 9-System automatisch gestartet und aktiviert, so dass es nicht notwendig ist, ihn manuell zu starten und zu aktivieren; wir können zum nächsten Schritt übergehen, nämlich dem Erhalt kostenloser SSL-Zertifikate von Let’s Encrypt CA.
Schritt 3 – Client installierenacme.sh
und Let’s Encrypt Zertifikat erhalten (optional)
Die Sicherung Ihrer Website mit HTTPS ist nicht notwendig, aber es ist eine gute Vorgehensweise, um den Traffic Ihrer Website zu sichern. Um das TLS-Zertifikat von Let’s Encrypt zu erhalten, verwenden wir den acme.sh-Client. Acme.sh ist eine reine Unix-Shell-Software zum Erhalten von TLS-Zertifikaten von Let’s Encrypt ohne Abhängigkeiten.
Laden Sie acme.sh herunter und installieren Sie es:
sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail [email protected]
cd ~
Überprüfen Sie die Version von acme.sh:
/etc/letsencrypt/acme.sh --version
# v2.8.0
Besorgen Sie sich RSA- und ECC/ECDSA-Zertifikate für Ihre Domain/Hostname:
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --keylength 2048
# ECDSA
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d example.com --keylength ec-256
Nachdem Sie die obigen Befehle ausgeführt haben, wird IhrZertifikateundSchlüsselwird drin sein:
- Für RSA:
/etc/letsencrypt/example.com
Verzeichnis. - Für ECC/ECDSA:
/etc/letsencrypt/example.com_ecc
Verzeichnis.
Schritt 3 – NGINX installieren und NGINX für Matomo konfigurieren
Matomo kann mit vielen gängigen Webserver-Programmen problemlos zusammenarbeiten. In diesem Tutorial haben wir Nginx ausgewählt.
Laden Sie Nginx aus dem Debian-Repository herunter und installieren Sie es:
sudo apt install -y nginx
Überprüfen Sie die Nginx-Version:
sudo nginx -v
# nginx version: nginx/1.10.3
Konfigurieren Sie Nginx für Matomo, indem Sie es ausführen:
sudo vim /etc/nginx/sites-available/matomo.conf
Und füllen Sie die Datei mit der folgenden Konfiguration:
server {
listen [::]:443 ssl http2;
listen 443 ssl http2;
listen [::]:80;
listen 80;
server_name example.com;
root /var/www/matomo/;
index index.php;
ssl_certificate /etc/letsencrypt/example.com/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/example.com/example.com.key;
ssl_certificate /etc/letsencrypt/example.com_ecc/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/example.com_ecc/example.com.key;
location ~ ^/(index|matomo|piwik|js/index).php {
include snippets/fastcgi-php.conf;
fastcgi_param HTTP_PROXY „“;
fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
}
location = /plugins/HeatmapSessionRecording/configs.php {
include snippets/fastcgi-php.conf;
fastcgi_param HTTP_PROXY „“;
fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
}
location ~* ^.+\.php$ {
deny all;
return 403;
}
location / {
try_files $uri $uri/ =404;
}
location ~ /(config|tmp|core|lang) {
deny all;
return 403;
}
location ~ \.(gif|ico|jpg|png|svg|js|css|htm|html|mp3|mp4|wav|ogg|avi|ttf|eot|woff|woff2|json)$ {
allow all;
}
location ~ /(libs|vendor|plugins|misc/user) {
deny all;
return 403;
}
}
HINWEIS:Für eine vollständige und produktionsreife Nginx-Konfiguration für Matomo besuchen Sie https://github.com/matomo-org/matomo-nginx.
Aktivieren Sie die neuematomo.conf
Konfiguration, indem Sie die Datei mit dem Verzeichnis verknüpfen.
sudo ln -s /etc/nginx/sites-available/matomo.conf /etc/nginx/sites-enabled
Überprüfen Sie die Nginx-Konfiguration auf Syntaxfehler:
sudo nginx -t
Nginx-Dienst neu laden:
sudo systemctl reload nginx.service
Schritt 4 – Matomo Analytics installieren
Erstellen/var/www
Verzeichnis:
sudo mkdir -p /var/www
Navigieren Sie zum/var/www
Verzeichnis:
cd /var/www/
Laden Sie die neueste Version von Matomo via wget herunter und entpacken Sie sie:
sudo wget https://builds.matomo.org/matomo.zip && sudo unzip matomo.zip
Entfernen Sie heruntergeladenematomo.zip
Datei:
sudo rm matomo.zip
Ändern Sie den Besitzer des/var/www/matomo
Verzeichnisses auf Benutzer.:
sudo chown -R www-data:www-data /var/www/matomo
Schritt 5 – Abschluss des Matomo Analytics-Setups
Öffnen Sie Ihre Website in einem Webbrowser und folgen Sie dem Matomo Web Installationsassistenten.
Zuerst sollte die Matomo Willkommensnachricht erscheinen. Klicken Sie auf die Schaltfläche „Weiter„:
Danach erscheint eine Seite „Systemprüfung“. Wenn etwas fehlt, erhalten Sie eine Warnung. Wenn alles mit einem grünen Häkchen versehen ist, klicken Sie auf die Schaltfläche „Weiter„, um zum nächsten Schritt zu gelangen:
Füllen Sie anschließend die Datenbankdetails aus und klicken Sie auf die Schaltfläche“ Weiter“Taste:
Wenn alles gut gelaufen ist, sollten Sie die Meldung „Tabellen mit Erfolg erstellt“ sehen:
Erstellen Sie ein Matomo Superuser-Konto und klicken Sie auf das Symbol“ Weiter“Taste:
Als nächstes richten Sie die erste Website ein, die Sie mit Matomo verfolgen und analysieren möchten. Später kannst du weitere Seiten hinzufügen, um mit Matomo zu verfolgen:
Als nächstes erhalten Sie den JavaScript-Tracking-Code für Ihre Website, den Sie hinzufügen müssen, um mit dem Tracking zu beginnen.
Als nächstes sollten Sie sehen, dass die Matomo-Installation abgeschlossen ist.
Herzlichen Glückwunsch! Deine Matomo-Installation ist abgeschlossen.