Cachet là một hệ thống trang trạng thái mã nguồn mở đẹp và mạnh mẽ được viết bằng PHP cho phép bạn truyền đạt tốt hơn về thời gian chết và lỗi hệ thống cho khách hàng, nhóm và cổ đông của mình. Ứng dụng cung cấp nhiều tính năng, trong đó quan trọng nhất là: API JSON mạnh mẽ, báo cáo sự kiện, số liệu, hỗ trợ phiên âm cho tin nhắn sự kiện, 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 PHP, Nginx, MySQL và Composer trên hệ thống CentOS 7.
Thiết lập múi giờ:
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:
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 của hệ điều hành CentOS:
Cài đặt PHP cũng như các gói cần thiết Tiện ích mở rộng PHP:
Để hiển thị PHP đã biên dịch trong các mô-đun, bạn có thể chạy:
Kiểm tra phiên bản PHP:
Khởi động và kích hoạt dịch vụ PHP-FPM:
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.
Tạo kho lưu trữ MariaDB 10.2 YUM cho CentOS:
Sao chép và dán văn bản sau vào đó:
Sau khi tệp đã được đặt đúng vị trí, hãy cài đặt MariaDB bằng cách chạy:
Kiểm tra phiên bản MariaDB:
Khởi động và bật MariaDB dịch vụ:
Chạy
Trả lời từng câu hỏi sau:
Kết nối với shell MariaDB với tư cách là người dùng root:
Tạo một cơ sở dữ liệuMariaDBrỗng và người dùng cho Cachet và ghi nhớ thông tin đăng nhập:
Thoát khỏi MariaDB:
Thay thế
Tải xuống và cài đặt acme.sh:
Kiểm tra phiên bản acme.sh:
Lấy chứng chỉRSAvàECC/ECDSAcho yourdomain/hostname:
Nếu bạn muốn có chứng chỉ giả để thử nghiệm, bạn có thể thêm
Sau khi chạy các lệnh trên, chứng chỉvà khóacủa bạn sẽ là trong:
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
Cài đặt/sao chép chứng chỉ vào /etc/letsencrypt[/ICODE]thư mục.
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 người dùng sudo bình thường:
Cài đặt NGINX:
Kiểm tra phiên bản NGINX:
Khởi động và bật dịch vụ NGINX:
Cấu hìnhNGINX cho Cachet bằng cách chạy:
Và điền cấu hình sau vào tệp:
Kiểm tra cấu hình NGINX:
Tải lạiNGINX:
Kiểm tra phiên bản Composer:
Thay đổi quyền sở hữu của thư mục
LƯU Ý:Thay thế{
Điều hướng đến thư mục gốc của tài liệu:
Tải xuống mã nguồn Cachet bằng Git:
Sao chép
Cài đặt các phụ thuộc Cachet bằng Composer:
Thiết lập khóa ứng dụng bằng đang chạy:
Cài đặt Cachet:
Cung cấp quyền sở hữu phù hợp:
Chạy
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.
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
Yêu cầu
Để chạy Cachet trên hệ thống CentOS 7, bạn sẽ cần một số thứ sau:- 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 ACentOS 7.
- Người dùng không phải root có quyền sudo.
Ban đầu các bước
Kiểm tra phiên bản CentOS của bạn:
Mã:
cat /etc/centos-release
Mã:
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Mã:
sudo yum upgdate -y
Mã:
sudo yum install -y curl wget vim gitunzip socat bash-completion
Bước 1 - Cài đặt PHP
Thiết lập kho lưu trữ YUM của Webtatic:
Mã:
sudo rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
Mã:
sudo yum install -y php72w-cli php72w-fpm php72w-common php72w-xml php72w-gd php72w-zip php72w-mbstring php72w-mysqlnd php72w-pgsql php72w-sqlite3 php72w-opcache php72w-apcu php72w-json
Mã:
php -m
ctype
curl
exif
fileinfo
. . .
. . .
Mã:
php --version
Mã:
sudo systemctl start php-fpm.service
sudo systemctl enable php-fpm.service
Bước 2 - Cài đặt MariaDB 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 MariaDBlàm máy chủ cơ sở dữ liệu.Tạo kho lưu trữ MariaDB 10.2 YUM cho CentOS:
Mã:
sudo vim /etc/yum.repos.d/MariaDB.repo
Mã:
# Danh sách kho lưu trữ MariaDB 10.2 CentOS - được tạo vào ngày 11-12-2017 23:19 UTC# http://downloads.mariadb.org/mariadb/repositories/[mariadb]name=MariaDBbaseurl=https://yum.mariadb.org/10.2/centos7-amd64gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDBgpgcheck=1
Mã:
sudo yum install -y MariaDB-server MariaDB-client
Mã:
mysql --version
# mysql Ver 15.1 Distrib 10.2.21-MariaDB, dành cho Linux (x86_64) bằng readline 5.1
Mã:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
cài đặt mysql_secure
script để cải thiện bảo mật MariaDBvà đặt mật khẩu cho MariaDBroot
người dùng:
Mã:
sudo mysql_secure_installation
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]
Mã:
sudo mysql -u root -p
# Nhập mật khẩu
Mã:
MariaDB>CREATE DATABASE dbname;
MariaDB>GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
MariaDB>FLUSH PRIVILEGES;
Mã:
MariaDB>exit
dbname
,username
vàpassword
bằng tên của bạn.Bước 3 - Cài đặt ứng dụng 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 web 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ỉ TLS từ Let's Encrypt, chúng tôi sẽ sử dụng ứng dụng 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 ~
Mã:
acme.sh --version
# v2.8.0
Mã:
# RSA 2048
acme.sh --issue--standalone -d example.com --keylength 2048
# ECDSA
acme.sh --issue --standalone -d example.com --keylength ec-256
--staging
flag vào các lệnh trên.Sau khi chạy các lệnh trên, chứng chỉvà khóacủa bạn sẽ là trong:
- Đối vớiRSA:
/home/username/example.com
thư mục. - Đối vớiECC/ECDSA:
/home/username/example.com_ecc
thư mục.
Mã:
acme.sh --list
/etc/letsencrypt
.
Mã:
mkdir -p /etc/letsecnrypt/example.com
[ICODE]sudo mkdir -p /etc/letsencrypt/example.com_ecc
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"
Sau khi lấy được chứng chỉ, hãy thoát khỏi người dùng root và trở lại 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ập https://docs.cachethq.io/docs/installing-cachet#section-running-cachet-on-apacheđể tìm hiểu thêm.Cài đặt NGINX:
Mã:
sudo yum install -y nginx
Mã:
sudo nginx -v
Mã:
sudo systemctl start nginx.service
sudo systemctl enable nginx.service
Mã:
sudo vim /etc/nginx/conf.d/cachet.conf
Mã:
server {
listen 80;
listen [::]:80;
listen 443 ssl;
listen [::]:443 ssl;
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 127.0.0.1:9000;
fastcgi_param TỆP_KẾ_HỆ_PHẦN $document_root$fastcgi_script_name;
fastcgi_index index.php;
fastcgi_keep_conn on;
}
}
Mã:
sudo nginx -t
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
Mã:
composer --version
#Composer phiên bản 1.8.4 2019-02-11 10:52:10
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
/var/www/cachet
đến {jour_user}
:
Mã:
sudo chown -R {your_user}:{your_user} /var/www/cachet
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
Mã:
git clone -b 2.4 --single-branch https://github.com/cachethq/Cachet.git .
.env.example
vào.env
tệp và định cấu hình cơ sở dữ liệu vàAPP_URL
cài đặt trong.env
tệp:
Mã:
cp .env.example .env
vim .env
Mã:
composer install --no-dev -o
Mã:
php artisan key:generate
Mã:
php artisan cachet:install
Mã:
sudo chown -R nginx:nginx /var/www/cachet
sudo vim /etc/php-fpm.d/www.conf
và đặt người dùng và nhóm thànhnginx
. Ban đầu, chúng sẽ được đặt thành apache:
Mã:
sudo vim /etc/php-fpm.d/www.conf
# user = nginx
# group = nginx
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.