如何在Freebsd 11上安装Matomo Analytics

・10 分钟阅读

使用不同的系统?

Matomo前身为Piwik,是一个开源分析平台,是谷歌分析的开源替代品,Matomo托管在gitHub ,它是一个完整的PHP/MySQL软件程序,你可以下载,并且安装在你自己的web服务器上,在本指南中,我们将在FreeBsd11服务器实例上安装Matomo。

要求

  • web服务器,如Nginx ,apache或IIS ,在本指南中,我们将使用Nginx ,
  • mysql/MariaDB版本5.5或更高版本,在本指南中,我们将使用MariaDB ,
  • PHP版本5.5.9或更高版本,
  • PHP扩展pdopdo_mysql,或mysqli扩展,

开始之前

查看FreeBSD版本。


uname -ro
# FreeBSD 11.2-RELEASE

确保你的FreeBSD系统是最新的。


freebsd-update fetch install
pkg update && pkg upgrade -y

如果sudovimunzipwgetbash软件包不存在于你的系统上,则安装它们。


pkg install -y sudo vim unzip wget bash

创建一个新的用户帐户,使用你首选的用户名(我们将使用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!

运行visudo命令,并且取消注释%wheel ALL=(ALL)ALL行,以允许wheel组的成员执行任何命令。


visudo

# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL

现在,使用su命令切换到新创建的用户。

 
su -johndoe

 

注:将johndoe替换为你的用户名。

设置时区。

 
sudo tzsetup

 

安装PHP

安装PHP,以及必要的PHP扩展。


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

检查版本。


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

软链接php.ini-productionphp.ini


sudo ln -s /usr/local/etc/php.ini-production /usr/local/etc/php.ini

启用并启动php fpm 。


sudo sysrc php_fpm_enable=yes
sudo service php-fpm start

安装MariaDB

下载并安装MariaDB 。


sudo pkg install -y mariadb102-client mariadb102-server

检查版本。


mysql --version
# mysql Ver 15.1 Distrib 10.2.17-MariaDB, for FreeBSD11.2 (amd64) using readline 5.1

启用和启动MariaDB 。


sudo sysrc mysql_enable="yes" 
sudo service mysql-server start

运行mysql_secure_installation脚本以提高MariaDB安装的安全性。


sudo mysql_secure_installation

以root用户身份登录到MariaDB 。


sudo mysql -u root -p
# Enter password:

创建新的MariaDB数据库和用户,并记住凭据。


CREATE DATABASE dbname;
GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;

退出MariaDB 。

 
exit

 

安装和配置Nginx

安装Nginx 。


sudo pkg install -y nginx

检查版本。


nginx -v
# nginx version: nginx/1.14.0

启用和启动Nginx 。


sudo sysrc nginx_enable=yes
sudo service nginx start

运行 sudo vim /usr/local/etc/nginx/matomo.conf 为Matomo配置nginx


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;
 }

}

保存文件并退出: +W+Q。

现在我们需要在主nginx.conf文件中包含matomo.conf文件。

运行 sudo vim /usr/local/etc/nginx/nginx.conf 将以下行添加到http {}块中。

 
include matomo.conf;

 

测试Nginx配置。

 
sudo nginx -t

 

重新加载Nginx 。


sudo service nginx reload

安装Matomo

创建文档root目录。


sudo mkdir -p /usr/local/www/matomo

/usr/local/www/matomo目录的所有权更改为johndoe


sudo chown -R johndoe:johndoe /usr/local/www/matomo

导航到文档root目录。


cd /usr/local/www/matomo

下载最新的Matomo版本并解压缩。


wget https://builds.matomo.org/matomo.zip
unzip matomo.zip
rm matomo.zip
mv matomo/* . && mv matomo/.* .
rmdir matomo

/usr/local/www/matomo目录的所有权更改为www


sudo chown -R www:www /usr/local/www/matomo

打开Web浏览器,并且导航到你已上传Matomo的IP/URL。你会看到"Matomo安装欢迎屏幕",如果有任何问题,matomo将识别它们,并且提供解决方案。按照屏幕上的说明完成Matomo安装。

Chinaxiong profile image