Cách cài đặt Cachet Status Page System trên Ubuntu 18.04 LTS

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 đạt tốt hơnthời gian ngừng hoạt động và sự cố hệ thống đến 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 tôi sẽ cài đặt hệ thống trang trạng thái Cachet bằng cách sử dụng PHP, Nginx, MySQL và Composer trên Ubuntu 18.04 LTS.

Yêu cầu​

  • Phiên bản PHP 7.1hoặc cao hơ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
  • Git

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

  • Hệ điều hành Ubuntu 18.04 LTS.
  • Người dùng không phải root có quyền sudo.

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

Kiểm tra Ubuntu của bạn version:
Mã:
lsb_release -ds
# Ubuntu 18.04.1 LTS
Thiết lập múi giờ:
Mã:
sudo dpkg-reconfigure tzdata
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 apt update && sudo apt upgrade -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 Ubuntu:
Mã:
sudo apt install -y curl wget vim gitunzip socat bash-completion

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

Cài đặt PHP cũng như các tiện ích mở rộng PHP cần thiết:
Mã:
sudo apt install -y php7.2 php7.2-cli php7.2-fpm php7.2-common php7.2-xml php7.2-gd php7.2-zip php7.2-mbstring php7.2-mysql php7.2-pgsql php7.2-sqlite3 php7.2-opcache php-apcu
Để hiển thị PHP được biên dịch trong các mô-đun, bạn có thể chạy:
Mã:
php -m

ctype
curl
exif
fileinfo
. . .
. . .
Kiểm tra phiên bản PHP:
Mã:
php --version

#PHP 7.2.10-0ubuntu0.18.04.1 (cli) (xây dựng: 13 tháng 9 năm 2018 13:45:02) (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
# với Zend OPcache v7.2.10-0ubuntu0.18.04.1, Bản quyền (c) 1999-2018, của Zend Technologies
Dịch vụ PHP-FPM được tự động khởi động và bật khi khởi động lại hệ thống Ubuntu 18.04, do đó không cần phải khởi động và bật dịch vụ này thủ công. Chúng ta có thể chuyển sang bước tiếp theo, đó là cài đặt và thiết lập cơ sở dữ liệu.

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

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

Cài đặt máy chủ cơ sở dữ liệu MySQL:
Mã:
sudo apt install -y mysql-server
Kiểm tra phiên bản MySQL:
Mã:
mysql --version
#mysql Ver 14.14 Distrib 5.7.25, dành cho Linux (x86_64) bằng trình bao bọc EditLine
Chạy cài đặt mysql_securescript để cải thiện bảo mật MySQL và đặt mật khẩu cho MySQLrootuser:
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 tới shell MySQL 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 MySQL rỗng và người dùng cho Cachet và ghi nhớ thông tin đăng nhập:
Mã:
mysql>CREATE DATABASE dbname;
mysql>GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
mysql>FLUSH PRIVILEGES;
Thoát khỏi MySQL:
Mã:
mysql>exit
Thay thếdbname,usernamepasswordbằ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)​

Bảo mật trang web của bạn bằng HTTPS là không cần thiết, 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. Để có được 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 đặt acme.sh:
Mã:
sudo su - root
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
./acme.sh --install --accountemail[emailprotected]
source ~/.bashrc
cd ~
Kiểm tra phiên bản acme.sh:
Mã:
acme.sh --version
# v2.8.0
Lấy chứng chỉRSAECC/ECDSAcho yourdomain/hostname:
Mã:
# RSA 2048
acme.sh --issue--standalone -d example.com --keylength 2048
# ECDSA
acme.sh --issue --standalone -d example.com --keylength ec-256
Nếu bạn muốn có chứng chỉ giả để thử nghiệm, bạn có thể thêm --stagingvào các lệnh trên.

Sau khi chạy các lệnh trên, chứng chỉkhóacủa bạn sẽ là trong:
  • Đối vớiRSA:/home/username/example.comthư mục.
  • Đối vớiECC/ECDSA:/home/username/example.com_eccthư mục.
Để liệt kê các chứng chỉ đã cấp, bạn có thể chạy:
Mã:
acme.sh --list
Tạo một thư mục để lưu trữ các chứng chỉ của bạn. Chúng tôi sẽ sử dụng thư mục /etc/letsencrypt.
Mã:
mkdir -p /etc/letsecnrypt/example.com
[ICODE]sudo mkdir -p /etc/letsencrypt/example.com_ecc
Cài đặt/sao chép chứng chỉ vào/etc/letsencryptthư mục.
Mã:
# RSA
acme.sh --install-cert -d example.com --cert-file /etc/letsencrypt/example.com/cert.pem --key-file /etc/letsencrypt/example.com/private.key --fullchain-file /etc/letsencrypt/example.com/fullchain.pem --reloadcmd "sudo systemctl reload nginx.service"
# ECC/ECDSA
acme.sh --install-cert -d example.com --ecc --cert-file /etc/letsencrypt/example.com_ecc/cert.pem --key-file /etc/letsencrypt/example.com_ecc/private.key --fullchain-file /etc/letsencrypt/example.com_ecc/fullchain.pem --reloadcmd "sudo systemctl reload nginx.service"
Tất cả các chứng chỉ sẽ được tự động gia hạn sau mỗi 60 ngày.

Sau khi lấy được chứng chỉ, hãy thoát khỏi người dùng root và trở lại thành người dùng sudo bình thường:
Mã:
exit

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

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.Nếu bạn thích máy chủ web Apache hơn Nginx, hãy truy cậphttps://docs.cachethq.io/docs/installing-cachet#section-running-cachet-on-apacheđể tìm hiểu thêm.

Cài đặt Nginx:
Mã:
sudo apt install -y nginx
Kiểm tra phiên bản Nginx:
Mã:
sudo nginx -v
#nginx phiên bản: nginx/1.14.0 (Ubuntu)
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 vào tệp với cấu hình sau:
Mã:
máy chủ {

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

 tên máy chủ trạng thái.example.com;

 gốc /var/www/cachet/public;

 chỉ mục index.php;

 chứng chỉ ssl /etc/letsencrypt/status.example.com/fullchain.cer;
 khóa chứng chỉ ssl /etc/letsencrypt/status.example.com/status.example.com.key;
 chứng chỉ ssl /etc/letsencrypt/status.example.com_ecc/fullchain.cer;
 khóa chứng chỉ ssl /etc/letsencrypt/status.example.com_ecc/status.example.com.key;

 location / {
 try_files $uri /index.php$is_args$args;
 }

 location ~ \.php$ {
 include fastcgi_params;
 fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 fastcgi_index index.php;
 fastcgi_keep_conn on;
 }

}
Kích hoạt cấu hìnhcachet.conf[/ICODE]mới bằng cách liên kết tệp tới sites-enabledthư mục:
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 toàn cầu:
Mã:
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"

php -r "if (hash_file('sha384', 'composer-setup.php') === '48e3236262b34d30969dca3c37281b3b4bbe3221bda826ac6a9a62d6444cdb0dcd0615698a5cbe587c3f0fe57a54d8f5') { 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.8.3 2019-01-30 08:31:33

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
Thay đổi quyền sở hữu của thư mục /var/www/cachetđến {jour_user}:
Mã:
sudo chown -R {your_user}:{your_user} /var/www/cachet
LƯU Ý:Thay thế{jour_user}bằng tên người dùng không phải root được tạo ban đầu của bạn.

Đ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:
Mã:
git clone -b 2.4 --single-branch https://github.com/cachethq/Cachet.git .
Sao chép.env.examplevào.envtệp và định cấu hình cơ sở dữ liệu vàAPP_URLcài đặt trong.envtệp:
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 đang chạy:
Mã:
php artisan key:generate
Cài đặt Cachet:
Mã:
php artisan cachet:install
Thay đổi quyền sở hữu thư mục/var/www/cachetthànhwww-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à định cấu hình tùy chọn thư:



Cấu hình các thiết lập 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 đến bảng điều khiển":



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 /dashboardvào URL trang web của bạn.


Liên kết​

 
Back
Bên trên