Cách cài đặt Cachet Status Page System trên Debian 9

theanh

Administrator
Nhân viên
Cachetlà một hệ thống trang trạng thái mã nguồn mở đẹp mắt và mạnh mẽ được viết bằng PHP cho phép bạn truyền đạtthời gian ngừng hoạt động và sự cố hệ thống tốt hơn cho khách hàng, nhóm và cổ đông của mình. Ứng dụng cung cấp cho bạn nhiều tính năng, đáng chú ý nhất trong số đó là: API JSON mạnh mẽ,báo cáo sự cố, số liệu, hỗ trợ markdown cho các thông báo sự cố, thông báo cho người đăng ký qua email, xác thực hai yếu tố. Trong hướng dẫn này, chúng ta sẽ cài đặt hệ thống trang trạng thái Cachet bằng cách sử dụng PHP, Nginx, MariaDB và Composer.

Yêu cầu​

  • Phiên bản PHP5.5.9 trở lên
  • Máy chủ HTTP hỗ trợ PHP (ví dụ: Nginx, Apache, Caddy)
  • Composer
  • Cơ sở dữ liệu được hỗ trợ: MySQL, PostgreSQL hoặc SQLite

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

  • Máy chủ chạy Debian 9.
    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 Debian:
Mã:
lsb_release -ds
#Debian GNU/Linux 9.5 (stretch)
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 của hệ điều hành:
Mã:
sudo apt update && sudo apt upgrade -y
Cài đặt các gói vim, git và socat:
Mã:
sudo apt install -y vim gitsocat sudo

Bước 1 - Cài đặt PHP​

Cài đặt PHP và các tiện ích mở rộng PHP cần thiết:
Mã:
sudo apt install -y php7.0 php7.0-cli php7.0-fpm php7.0-common php7.0-xml php7.0-gd php7.0-zip php7.0-mbstring php7.0-mysql php7.0-pgsql php7.0-sqlite3 php7.0-mcrypt php-apcu
Kiểm tra phiên bản PHP:
Mã:
php --version
#PHP 7.0.30-0+deb9u1 (cli) (được xây dựng: 14 tháng 6 năm 2018 13:50:25) ( NTS )

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

Cachet hỗ trợ cơ sở dữ liệu MySQL/MariaDB, PostgreSQL và SQLite3. 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 apt install -y mariadb-server
Kiểm tra phiên bản MariaDB:
Mã:
mysql --version
#mysql Ver 15.1 Distrib 10.1.26-MariaDB, dành cho debian-linux-gnu (x86_64) bằng readline 5.2
Chạy tập lệnh mysql_secure installation để cải thiện bảo mật MariaDB và đặt mật khẩu cho người dùng root MySQL:
Mã:
sudo mysql_secure_installation
Trả lời từng câu hỏi sau:
Mã:
Nhập mật khẩu hiện tại cho root (nhập nếu không nhập): [B]Nhấn Enter[/b]
Đặt mật khẩu root? [Y/n] [B]Y[/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 MySQL với tư cách là người dùng root:
Mã:
mysql -u root -p
# Nhập mật khẩu
Tạo cơ sở dữ liệu MariaDB trống và người dùng cho Cachet và ghi nhớ thông tin đăng nhập:
Mã:
MariaDB [(none)]> CREATE DATABASE dbname;
MariaDB [(none)]> GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
MariaDB [(none)]>FLUSH PRIVILEGES;
Thoát khỏi MariaDB:
Mã:
MariaDB [(none)]> exit
Thay thế dbname, tên người dùng và mật khẩu bằng tên của riêng bạn.

Bước 3 - Cài đặt máy khách Acme.sh 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 trạng thái của bạn bằng HTTPS, nhưng đây là một biện pháp tốt để bảo mật lưu lượng truy cập trang web của bạn. Để lấy chứng chỉ SSL từ Let's Encrypt, chúng ta sẽ sử dụng máy khách Acme.sh. Acme.sh là phần mềm shell unix thuần túy dùng để lấy chứng chỉ SSL từ Let's Encrypt mà không cần phụ thuộc.

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 Acme.sh:
Mã:
/etc/letsencrypt/acme.sh --version
# v2.8.0
Lấy chứng chỉ RSAECC/ECDSA cho 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 status.example.com --ocsp-must-staple --keylength 2048
# ECDSA
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d status.example.com --ocsp-must-staple --keylength ec-256
Sau khi chạy các lệnh trên, chứng chỉkhóa của bạn sẽ nằm trong:
  • Đối với RSA: thư mục /etc/letsencrypt/status.example.com.
  • Đối với ECC/ECDSA: thư mục /etc/letsencrypt/status.example.com_ecc.

Bước 4 - Cài đặt và configureNginx​

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

Cài đặt Nginx:
Mã:
sudo apt install -y nginx
Kiểm tra phiên bản Nginx:
Mã:
sudo nginx -v
#nginx version: nginx/1.10.3
Cấu hình Nginx cho Cachet bằng cách chạy:
Mã:
sudo vim /etc/nginx/sites-available/cachet.conf
Và điền cấu hình sau vào tệp:
Mã:
server {

 listen 80;
 listen [::]:80;

 server_name status.example.com;

 root /var/www/cachet/public;

 index index.php;

 ssl_certificate /etc/letsencrypt/status.example.com/fullchain.cer;
 khóa_chứng_nhận_ssl /etc/letsencrypt/status.example.com/status.example.com.key;
 khóa_chứng_nhận_ssl /etc/letsencrypt/status.example.com_ecc/fullchain.cer;
 khóa_chứng_nhận_ssl /etc/letsencrypt/status.example.com_ecc/status.example.com.key;

 vị trí / {
 try_files $uri /index.php$is_args$args;
 }

 vị trí ~ \.php$ {
 bao gồm fastcgi_params;
 fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
 fastcgi_param TÊN_TỆP_KỊCH_SỬ $document_root$fastcgi_script_name;
 fastcgi_index index.php;
 fastcgi_keep_conn on;
 }

}
Kích hoạt cấu hình cachet.conf mới bằng cách liên kết tệp đến thư mục sites-enabled:
Mã:
sudo ln -s /etc/nginx/sites-available/cachet.conf /etc/nginx/sites-enabled/
Kiểm tra cấu hình NGINX:
Mã:
sudo nginx -t
Tải lại Nginx:
Mã:
sudo systemctl reload nginx.service

Bước 5 - Cài đặt Composer​

Cài đặt Composer, trình quản lý phụ thuộc PHP trên toàn cầu:
Mã:
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"

php -r "if (hash_file('SHA384', 'composer-setup.php') === '544e09ee996cdf60ece3804abc52599c22b1f40f4323403c44d44fdfdd586475ca9813a858088ffbc1f233e9b180f061') { echo 'Đã xác minh trình cài đặt'; } else { echo 'Trình cài đặt bị hỏng'; unlink('composer-setup.php'); } echo PHP_EOL;"

php composer-setup.php

php -r "unlink('composer-setup.php');"

sudo mv composer.phar /usr/local/bin/composer
Kiểm tra phiên bản Composer:
Mã:
composer --version
#Composer phiên bản 1.7.2 2018-08-16 16:57:12

Bước 6 - Cài đặt Cachet​

Tạo thư mục gốc của tài liệu nơi Cachet sẽ lưu trú:
Mã:
sudo mkdir -p /var/www/cachet
Điều hướng đến thư mục gốc của tài liệu:
Mã:
cd /var/www/cachet
Tải xuống mã nguồn Cachet bằng Git và kiểm tra bản phát hành được gắn thẻmới nhất:
Mã:
git clone https://github.com/cachethq/Cachet.git .
git tag -l
git checkout v2.3.15
Sao chép .env.example vào tệp .env và định cấu hình cơ sở dữ liệu và cài đặt APP_URL trong tệp .env:
Mã:
cp .env.example .env
vim .env
Cài đặt các phụ thuộc Cachet bằng Composer:
Mã:
composer install --no-dev -o
Thiết lập khóa ứng dụng bằng cách chạy:
Mã:
php artisan key:generate
Cài đặt Cachet:
Mã:
php artisan app:install
Thay đổi quyền sở hữu thư mục /var/www/cachet thành www-data:
Mã:
sudo chown -R www-data:www-data /var/www/cachet
Mở trang web của bạn trong trình duyệt web và làm theo hướng dẫn trên màn hình để hoàn tất cài đặt Cachet.

Bước 7 - Hoàn tất thiết lập Cachet​

Chọn trình điều khiển bộ nhớ đệm và phiên và cấu hình tùy chọn thư:



Cấu hình cài đặt chung của trang web như tên trang web, tên miền trang web, múi giờ và ngôn ngữ:



Tạo tài khoản người dùng quản trị:



Sau đó, bạn sẽ nhận được thông báo rằng Cachet đã được cấu hình thành công. Bạn có thể mở bảng điều khiển Cachet bằng cách nhấn nút "Đi tới bảng điều khiển":



Việc cài đặt và thiết lập Cachet đã hoàn tất.

Để truy cập bảng điều khiển Cachet, hãy thêm /dashboard vào URL trang web của bạn.




Liên kết​

 
Back
Bên trên