Cách cài đặt Matomo Web Analytics trên Fedora 29

theanh

Administrator
Nhân viên
Matomo (trước đây làPiwik)là mộtứng dụng phân tích webmiễn phívànguồn mởdo một nhóm các nhà phát triển quốc tế phát triển, chạy trên máy chủ webPHP/MySQL. Ứng dụng này theo dõi các lượt truy cập trực tuyếnvào một hoặc nhiềutrang webvà hiển thị báo cáo về các lượt truy cập này để phân tích. Bạn có thể coi ứng dụng này như một giải pháp thay thế cho Google Analytics. Matomo là mã nguồn mở và mã của ứng dụng này được công khai trên Github. Một số tính năng của nó là:Kiểm tra A/B, Bản đồ nhiệt, Phễu, API theo dõi và báo cáo, Google AdWords, Quảng cáo trên Facebook, Quảng cáo Bing, Chi phí cho mỗi lần nhấp (CPC), v.v. Hướng dẫn này sẽ chỉ cho bạn cách cài đặt Matomo trên hệ thống Fedora 29 bằng cách sử dụng Nginx làm máy chủ web và chúng tôi sẽ bảo mật trang web bằng chứng chỉ SSL Let's Encrypt.

Yêu cầu​

Để chạy Matomo (Piwik) trên hệ thống Fedora 29 của bạn, bạn sẽ cần một số thứ:
  • Máy chủ web như Apache, Nginx, IIS.
  • Phiên bản PHP 5.5.9 trở lên với pdovà pdo_mysqlhoặc mysqli, gd, xml, curl và mbsting. Khuyến khích sử dụng PHP 7 trở lên.
  • MySQL phiên bản 5.5 trở lên hoặc phiên bản MariaDB tương đương. MySQL 5.7+ được khuyến nghị.

Điều kiện tiên quyết​

  • Hệ điều hành đang chạyFedora 29.
  • Người dùng không phải root có quyền sudo.

Các bước ban đầu​

Kiểm tra phiên bản Fedora của bạn:
Mã:
cat /etc/fedora-release
# Fedora phát hành 29 (Hai mươi Chín)
Thiết lập múi giờ:
Mã:
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Cập nhật các gói hệ điều hành (phần mềm) của bạn. Đây là bước đầu tiên quan trọng vì nó đảm bảo bạn có các bản cập nhật và bản sửa lỗi bảo mật mới nhất cho các gói phần mềm mặc định của hệ điều hành:
Mã:
sudo dnf check-update; sudo dnf update -y
Cài đặt một số gói thiết yếu cần thiết cho việc quản trị cơ bản hệ điều hành Fedora:
Mã:
sudo dnf install -y curl wget vim gitunzip socat

Bước 1 - Cài đặt MariaDB và tạo cơ sở dữ liệu cho Matomo​

Matomo hỗ trợ cơ sở dữ liệu MySQL và MariaDB. Trong hướng dẫn này, chúng ta sẽ sử dụng MariaDB làm máy chủ cơ sở dữ liệu.

Cài đặt máy chủ cơ sở dữ liệu MariaDB:
Mã:
sudo dnf install -y mariadb-server
Kiểm tra phiên bản MariaDB:
Mã:
mysql --version
#mysql Ver 15.1 Distrib 10.3.11-MariaDB, dành cho Linux (x86_64) bằng readline 5.1
Khởi động và bật dịch vụ MariaDB:
Mã:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
Chạymysql_secure installationscript để cải thiện bảo mật MariaDB và đặt mật khẩu cho MariaDBrootngười dùng:
Mã:
sudo mysql_secure_installation
Trả lời từng câu hỏi sau:
Mã:
Bạn có muốn thiết lập plugin VALIDATE PASSWORD không? [B]N[/b]
Mật khẩu mới: [B]your_secure_password[/b]
Nhập lại mật khẩu mới:[B]your_secure_password[/b]
Xóa người dùng ẩn danh? [Y/n] [B]Y[/b]
Không cho phép đăng nhập root từ xa? [Y/n] [B]Y[/b]
Xóa cơ sở dữ liệu thử nghiệm và quyền truy cập vào cơ sở dữ liệu đó? [Y/n] [B]Y[/b]
Tải lại bảng đặc quyền ngay bây giờ? [Y/n] [B]Y[/b]
Kết nối với shell MariaDB với tư cách là người dùng root:
Mã:
sudo mysql -u root -p
# Nhập mật khẩu
Tạo một cơ sở dữ liệu MariaDB trốngvà người dùng forMatomovà ghi nhớ thông tin đăng nhập:
Mã:
MariaDB>CREATE DATABASE dbname;
MariaDB>GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
MariaDB>FLUSH PRIVILEGES;
Thoát khỏi MariaDB:
Mã:
mysql>thoát
Thay thếdbname,usernamepasswordbằng tên của bạn.

Bước 2 - Cài đặt PHP và các tiện ích mở rộng PHP cần thiết​

Cài đặt PHP cũng như các tiện ích mở rộng PHP cần thiết:
Mã:
sudo dnf install -y php php-cli php-fpm php-common php-curl php-gd php-xml php-mbstring php-mysqlnd php-json
Kiểm tra phiên bản PHP:
Mã:
php --version

#PHP 7.2.14 (cli) (được xây dựng: 8 tháng 1 2019 09:59:17) ( NTS )
# Bản quyền (c) 1997-2018 The PHP Group
# Zend Engine v3.2.0, Bản quyền (c) 1998-2018 Zend Technologies
Khởi động và kích hoạt dịch vụ PHP-FPM:
Mã:
sudo systemctl start php-fpm.service
sudo systemctl enable php-fpm.service
Chúng ta có thể chuyển sang bước tiếp theo, đó là lấy chứng chỉ SSL miễn phí từ Let's Encrypt CA.

Bước 3 - Cài đặtacme.shclient và lấy chứng chỉ Let's Encrypt (tùy chọn)​

Không nhất thiết phải bảo mật trang web của bạn bằng HTTPS, nhưng là một biện pháp tốt để bảo vệ lưu lượng truy cập trang web của bạn. Để lấy chứng chỉ TLS từ Let's Encrypt, chúng tôi sẽ sử dụng máy khách Acme.sh. Acme.sh là phần mềm shell UNIX thuần túy để lấy chứng chỉ TLS từ Let's Encrypt mà không phụ thuộc vào bất kỳ thứ gì.

Tải xuống và cài đặtAcme.sh:
Mã:
sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail[emailprotected]
cd ~
Kiểm tra phiên bản của Acme.sh:
Mã:
/etc/letsencrypt/acme.sh --version
# v2.8.0
Lấy chứng chỉRSAECC/ECDSAcho tên miền/tên máy chủ của bạn:
Mã:
# 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
Sau khi chạy các lệnh trên, chứng chỉkhóacủa bạn sẽ nằm trong:
  • Đối vớiRSA: /etc/letsencrypt/example.comthư mục.
  • Đối vớiECC/ECDSA: /etc/letsencrypt/example.com_eccthư mục.

Bước 3 - Cài đặt NGINX và cấu hình NGINX cho Matomo​

Matomo có thể hoạt động tốt với nhiều phần mềm máy chủ web phổ biến. Trong hướng dẫn này, chúng tôi đã chọn Nginx.

Tải xuống và cài đặt Nginx từ kho lưu trữ Fedora:
Mã:
sudo dnf install -y nginx
Kiểm tra phiên bản Nginx:
Mã:
sudo nginx -v
#nginx version: nginx/1.14.1
Khởi động và kích hoạt dịch vụ Nginx:
Mã:
sudo systemctl start nginx.service
sudo systemctl enable nginx.service
Cấu hình Nginx cho Matomo bằng cách chạy:
Mã:
sudo vim /etc/nginx/conf.d/matomo.conf
Và điền vào tệp với cấu hình sau:
Mã:
máy chủ {

 lắng nghe [::]:443 ssl http2;
 lắng nghe 443 ssl http2;
 lắng nghe [::]:80;
 lắng nghe 80;

 tên_máy_chủ example.com;
 gốc /var/www/matomo/;
 chỉ mục index.php;

 chứng_chỉ_số_ssl /etc/letsencrypt/example.com/fullchain.cer; 
 khóa_chứng_chỉ_số_ssl /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;

 vị trí ~ ^/(index|matomo|piwik|js/index).php {
 fastcgi_split_path_info ^(.+\.php)(/.+)$;
 try_files $fastcgi_script_name =404;
 đặt $path_info $fastcgi_path_info;
 fastcgi_param PATH_INFO $path_info;
 fastcgi_index index.php;
 bao gồm fastcgi.conf;
 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 fastcgi_param SCRIPT_NAME $fastcgi_script_name;
 fastcgi_param HTTP_PROXY ""; 
 fastcgi_pass unix:/run/php-fpm/www.sock; 
 }
 
 vị trí = /plugins/HeatmapSessionRecording/configs.php {
 fastcgi_split_path_info ^(.+\.php)(/.+)$;
 try_files $fastcgi_script_name =404;
 đặt $path_info $fastcgi_path_info;
 fastcgi_param PATH_INFO $path_info;
 fastcgi_index index.php;
 bao gồm fastcgi.conf;
 fastcgi_param TỆP_KẾ_GÓI $document_root$fastcgi_script_name;
 fastcgi_param TỆP KẾ_HỆ_K ... fastcgi_param HTTP_PROXY "";
 fastcgi_pass unix:/run/php-fpm/www.sock;
 }

 vị trí ~* ^.+\.php$ {
 từ chối tất cả;
 trả về 403;
 }

 vị trí / {
 try_files $uri $uri/ =404;
 }
 
 vị trí ~ /(config|tmp|core|lang) {
 từ chối tất cả;
 trả về 403;
 }

 vị trí ~ \.(gif|ico|jpg|png|svg|js|css|htm|html|mp3|mp4|wav|ogg|avi|ttf|eot|woff|woff2|json)$ {
 cho phép tất cả;
 }

 vị trí ~ /(libs|vendor|plugins|misc/user) {
 từ chối tất cả;
 trả về 403;
 }

}
LƯU Ý:Để biết cấu hình Nginx hoàn chỉnh và sẵn sàng cho sản xuất cho Matomo, hãy truy cậphttps://github.com/matomo-org/matomo-nginx.

Kiểm tra cấu hình Nginx để biết lỗi cú pháp:
Mã:
sudo nginx -t
Tải lại dịch vụ Nginx:
Mã:
sudo systemctl reload nginx.service

Bước 4 - Cài đặt Matomo Analytics​

Tạo thư mục/var/www:
Mã:
sudo mkdir -p /var/www/
Điều hướng đến thư mục/var/www:
Mã:
cd /var/www/
Tải xuống bản phát hành mới nhất của Matomo qua wget và giải nén nó:
Mã:
sudo wget https://builds.matomo.org/matomo.zip && sudo unzip matomo.zip
Xóa tệpmatomo.zip đã tải xuống:
Mã:
sudo rm matomo.zip
Thay đổi quyền sở hữu thư mục/var/www/matomothànhnginxuser:
Mã:
sudo chown -R nginx:nginx /var/www/matomo
Chạysudo vim /etc/php-fpm.d/www.confvà đặt người dùng và nhóm thànhnginx. Ban đầu, nó sẽ được thiết lập thành người dùng và nhómapache.
Mã:
sudo vim /etc/php-fpm.d/www.conf
# user = nginx
# group = nginx
Khởi động lại dịch vụ PHP-FPM.
Mã:
sudo systemctl restart php-fpm.service

Bước 5 - Hoàn tất thiết lập Matomo Analytics​

Mở trang web của bạn trong trình duyệt web và làm theo trình hướng dẫn cài đặt web Matomo.

Đầu tiên, thông báo chào mừng Matomo sẽ xuất hiện. Nhấp vào nút"Tiếp theo":



Sau đó, bạn sẽ thấy trang"Kiểm tra hệ thống". Nếu thiếu thứ gì đó, bạn sẽ thấy cảnh báo. Nếu mọi thứ đều được đánh dấu bằng dấu kiểm màu xanh lá cây, hãy nhấp vào nút"Tiếp theo" để tiến hành bước tiếp theo:



Tiếp theo, điền thông tin chi tiết về cơ sở dữ liệu và nhấp vào nút"Tiếp theo":



Nếu mọi thứ diễn ra tốt đẹp với thiết lập cơ sở dữ liệu, bạn sẽ thấy thông báo"Bảng đã được tạo thành công!":



Tạo siêu tài khoản người dùng Matomo và nhấp vào nút"Tiếp theo":



Tiếp theo, hãy thiết lập trang web đầu tiên mà bạn muốn theo dõi và phân tích bằng Matomo. Sau đó, bạn có thể thêm nhiều trang web để theo dõi bằng Matomo:



Tiếp theo, bạn sẽ được cung cấp mã theo dõi JavaScript cho trang web của mình mà bạn cần thêm để bắt đầu theo dõi.



Tiếp theo, bạn sẽ thấy quá trình cài đặt Matomo đã hoàn tất.



Xin chúc mừng! Quá trình cài đặt Matomo của bạn đã hoàn tất.

Liên kết​

 
Back
Bên trên