Matomo (anciennement Piwik) est une plate-forme d'analyse open source, une alternative ouverte à Google Analytics. La source Matomo est hébergée sur GitHub . Il s'agit d'un logiciel PHP / MySQL complet que vous téléchargez et installez sur votre propre serveur Web. Dans ce guide, nous allons installer Matomo sur une nouvelle instance de serveur FreeBSD 11 Vultr.
Exigences
- Un serveur Web tel que Nginx, Apache ou IIS. Dans ce guide, nous utiliserons Nginx.
- MySQL / MariaDB version 5.5 ou supérieure. Dans ce guide, nous utiliserons MariaDB.
- PHP version 5.5.9 ou supérieure.
- Extensions PHP
pdo
et pdo_mysql
, ou l' mysqli
extension.
Avant que tu commences
Vérifiez la version de FreeBSD.
uname -ro
# FreeBSD 11.2-RELEASE
Assurez-vous que votre système FreeBSD est à jour.
freebsd-update fetch install
pkg update && pkg upgrade -y
Installer sudo
, vim
, unzip
, wget
et les bash
paquets si elles ne sont pas présents sur votre système.
pkg install -y sudo vim unzip wget bash
Créez un nouveau compte utilisateur avec votre nom d'utilisateur préféré (nous utiliserons johndoe
).
adduser
# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!
Exécutez la visudo
commande et décommentez la %wheel ALL=(ALL) ALL
ligne pour permettre aux membres du wheel
groupe d'exécuter n'importe quelle commande.
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
Maintenant, passez à votre nouvel utilisateur créé avec la su
commande.
su - johndoe
REMARQUE: remplacez johndoe
par votre nom d'utilisateur.
Configurez le fuseau horaire.
sudo tzsetup
Installer PHP
Installez PHP, ainsi que les extensions PHP nécessaires.
sudo pkg install -y php72 php72-ctype php72-curl php72-dom php72-hash php72-iconv php72-gd php72-json php72-mbstring php72-openssl php72-session php72-simplexml php72-xml php72-zip php72-zlib php72-pdo php72-pdo_mysql php72-mysqli php72-filter php72-ftp php72-tokenizer php72-calendar php72-pecl-APCu php72-opcache
Vérifiez la version.
php --version
# PHP 7.2.10 (cli) (built: Oct 2 2018 01:30:18) ( NTS )
# Copyright (c) 1997-2018 The PHP Group
# Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
# with Zend OPcache v7.2.10, Copyright (c) 1999-2018, by Zend Technologies
Lien logiciel php.ini-production
vers php.ini
.
sudo ln -s /usr/local/etc/php.ini-production /usr/local/etc/php.ini
Activez et démarrez PHP-FPM.
sudo sysrc php_fpm_enable=yes
sudo service php-fpm start
Installer MariaDB
Téléchargez et installez MariaDB.
sudo pkg install -y mariadb102-client mariadb102-server
Vérifiez la version.
mysql --version
# mysql Ver 15.1 Distrib 10.2.17-MariaDB, for FreeBSD11.2 (amd64) using readline 5.1
Activez et démarrez MariaDB.
sudo sysrc mysql_enable="yes"
sudo service mysql-server start
Exécutez le mysql_secure_installation
script pour améliorer la sécurité de votre installation MariaDB.
sudo mysql_secure_installation
Connectez-vous à MariaDB en tant qu'utilisateur root.
sudo mysql -u root -p
# Enter password:
Créez une nouvelle base de données et un nouvel utilisateur MariaDB et mémorisez les informations d'identification.
CREATE DATABASE dbname;
GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
Quittez MariaDB.
exit
Installez Nginx.
sudo pkg install -y nginx
Vérifiez la version.
nginx -v
# nginx version: nginx/1.14.0
Activez et démarrez Nginx.
sudo sysrc nginx_enable=yes
sudo service nginx start
Exécutez sudo vim /usr/local/etc/nginx/matomo.conf
et configurez Nginx pour Matomo.
server {
listen [::]:80;
listen 80;
server_name matomo.example.com;
root /usr/local/www/matomo/;
index index.php;
location ~ ^/(index|matomo|piwik|js/index).php {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
try_files $fastcgi_script_name =404;
set $path_info $fastcgi_path_info;
fastcgi_param PATH_INFO $path_info;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
fastcgi_param HTTP_PROXY "";
fastcgi_pass 127.0.0.1:9000;
}
location = /plugins/HeatmapSessionRecording/configs.php {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
try_files $fastcgi_script_name =404;
set $path_info $fastcgi_path_info;
fastcgi_param PATH_INFO $path_info;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
fastcgi_param HTTP_PROXY "";
fastcgi_pass 127.0.0.1:9000;
}
location ~* ^.+\.php$ {
deny all;
return 403;
}
location / {
try_files $uri $uri/ =404;
}
location ~ /(config|tmp|core|lang) {
deny all;
return 403;
}
location ~ /\.ht {
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;
expires 1h;
add_header Pragma public;
add_header Cache-Control "public";
}
location ~ /(libs|vendor|plugins|misc/user) {
deny all;
return 403;
}
location ~/(.*\.md|LEGALNOTICE|LICENSE) {
default_type text/plain;
}
}
Enregistrez le fichier et quittez avec :+ W+ Q.
Maintenant, nous devons inclure le matomo.conf
fichier dans le nginx.conf
fichier principal .
Exécutez sudo vim /usr/local/etc/nginx/nginx.conf
et ajoutez la ligne suivante au http {}
bloc.
include matomo.conf;
Testez la configuration Nginx.
sudo nginx -t
Recharger Nginx.
sudo service nginx reload
Installer Matomo
Créez un répertoire racine de document.
sudo mkdir -p /usr/local/www/matomo
Changez la propriété du /usr/local/www/matomo
répertoire en johndoe
.
sudo chown -R johndoe:johndoe /usr/local/www/matomo
Accédez au répertoire racine du document.
cd /usr/local/www/matomo
Téléchargez la dernière version de Matomo et décompressez-la.
wget https://builds.matomo.org/matomo.zip
unzip matomo.zip
rm matomo.zip
mv matomo/* . && mv matomo/.* .
rmdir matomo
Changez la propriété du /usr/local/www/matomo
répertoire en www
.
sudo chown -R www:www /usr/local/www/matomo
Ouvrez votre navigateur Web et accédez à l'IP / URL vers laquelle vous avez téléchargé Matomo. Vous verrez "l'écran d'accueil de l'installation de Matomo" . En cas de problème, Matomo les identifiera et proposera une solution. Suivez les instructions à l'écran pour terminer l'installation de Matomo.