Cách cài đặt Pagekit CMS trên CentOS 7

theanh

Administrator
Nhân viên
Pagekit là CMS nguồn mở hiện đại, trực quan, theo mô-đun và linh hoạt (giấy phép MIT)được xây dựng bằng các thành phần Symfony và Vue.js.Nó cung cấp cho bạn các công cụ để tạo ra các trang web đẹp mắt. Nó có một hệ sinh thái chủ đề và plugin phong phú.

Trong hướng dẫn này, chúng tôi sẽ hướng dẫn bạn quy trình cài đặt Pagekit CMS trên hệ điều hành CentOS 7bằng cách sử dụng NGINX làm máy chủ web, MariaDB làm máy chủ cơ sở dữ liệu và tùy chọn bạn có thể bảo mật lớp truyền tải bằng cách sử dụng máy khách acme.sh và chứng chỉ Let's Encrypt để thêm hỗ trợ SSL.

Yêu cầu​

Để cài đặt Pagekit, hãy đảm bảo máy chủ của bạn đáp ứng các yêu cầu sau:
  • Apache phiên bản 2.2 trở lên hoặc máy chủ web NGINX.
  • MySQL phiên bản 5.1 trở lên hoặc SQLite 3.
  • PHP phiên bản 5.5.9 trở lên.
  • Các phần mở rộng PHP bắt buộc: JSON, Session, ctype, Tokenizer, SimpleXML, DOM, mbstring, PCRE 8.0+, ZIP và PDO với trình điều khiển MySQL hoặc SQLite.
  • Các phần mở rộng PHP tùy chọn: cURL, iconv và XML Parser, cũng như APC hoặc XCache để lưu trữ đệm.

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

  • Một hệ thống đang chạyCentOS 7.
  • Một 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 CentOS của bạn:
Mã:
cat /etc/centos-release
# CentOS Linux phát hành 7.6.1810 (Core)
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 yum 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 CentOS:
Mã:
sudo yum install -y curl wget vim gitunzip socat bash-completion epel-release

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

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
Cài đặt PHP cũng như các tiện ích mở rộng PHP cần thiết:
Mã:
sudo yum install -y php72w php72w-cli php72w-fpm php72w-common php72w-mbstring php72w-zip php72w-mysql php72w-sqlite3 php72w-curl php72w-xml
Để 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.14 (cli) (được xây dựng: 12 tháng 1 năm 2019 12:47:33) (NTS)
# Bản quyền (c) 1997-2018 The PHP Group
# Zend Engine v3.0.0, Bản quyền (c) 1998-2017 Zend Technologies
# với Zend OPcache v7.2.14, Bản quyền (c) 1999-2018, của 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à cài đặt cơ sở dữ liệu và thiết lập.

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

Pagekit CMS hỗ trợ cơ sở dữ liệu MySQL, MariaDB và SQLite.Tronghướng dẫn này, chúng ta sẽ sử dụng MariaDB làm máy chủ cơ sở dữ liệu. Nếu bạn muốn cài đặt MySQL gốc, bạn có thể thêm và sử dụng kho lưu trữ MySQL chính thức do Oracle quản lý.

Cài đặt máy chủ cơ sở dữ liệu MariaDB:
Mã:
sudo yum install -y mariadb-server
Kiểm tra phiên bản MariaDB:
Mã:
mysql --version
Khởi động và kích hoạt dịch vụ MariaDB:
Mã:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
Chạy mysql_secure installation script để cải thiện bảo mật MariaDB và đặt mật khẩu cho MariaDB rootuser:
Mã:
sudo mysql_secure_installation
Trả lời từng câu hỏi câu hỏi:
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ống và người dùng cho Bolt CMS và 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ã:
MariaDB>exit
Thay thế dbname, usernamepassword 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 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ỉ 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 để lấy chứng chỉ SSL 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 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.1
Lấy chứng chỉ RSAECC/ECDSA cho tên miền/tên máy chủ của bạn:
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 --stagingflag vào các lệnh trên.

Để 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/letsencrypt/example.com
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"
Sau khi chạy các lệnh trên, chứng chỉkhóacủa bạn sẽ nằm trong:
  • Đối với RSA:/etc/letsencrypt/example.com thư mục.
  • Đối với ECC/ECDSA:/etc/letsencrypt/example.com_ecc 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ỉ, thoát khỏi người dùng root và quay lại người dùng sudo bình thường:
Mã:
exit

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

Tải xuống và cài đặt Nginx từ kho lưu trữ CentOS:
Mã:
sudo yum install -y nginx
Kiểm tra phiên bản Nginx:
Mã:
nginx -v
#nginx phiên bản: nginx/1.12.2
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ìnhNGINX cho Pagekit bằng cách chạy:
Mã:
sudo vim /etc/nginx/conf.d/pagekit.conf
Và điền cấu hình sau vào tệp:
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; chỉ mục index.php index.html; gốc /var/www/pagekit;
 chứng chỉ ssl /etc/letsencrypt/example.com/fullchain.pem;
 khóa chứng chỉ ssl /etc/letsencrypt/example.com/private.key;
 chứng chỉ ssl /etc/letsencrypt/example.com_ecc/fullchain.pem;
 khóa chứng chỉ ssl /etc/letsencrypt/example.com_ecc/private.key;
 vị trí / { try_files $uri $uri/ /index.php?$query_string; }

 vị trí ~ \.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; include fastcgi.conf;
 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 fastcgi_pass 127.0.0.1:9000;
 }}
Kiểm tra cấu hìnhNGINX để tìm 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 5 - Tải xuống và cài đặt Pagekit CMS​

Tạo thư mục gốc của tài liệu nơi Pagekit sẽ lưu trú:
Mã:
sudo mkdir -p /var/www/pagekit
Thay đổi quyền sở hữu của thư mục /var/www/pagekit tới [your_user]:
Mã:
sudo chown -R [your_user]:[your_user] /var/www/pagekit
Điều hướng đến thư mục gốc của tài liệu:
Mã:
cd /var/www/pagekit
Tải xuống bản phát hành ổn định mới nhất của Pagekit CMS qua wget:
Mã:
wget https://github.com/pagekit/pagekit/releases/download/1.0.16/pagekit-1.0.16.zip
Giải nén nội dung Pagekit CMS và xóa tệp .zip đã tải xuống.
Mã:
giải nén pagekit-1.0.16.zip
rm pagekit-1.0.16.zip
Cung cấp tệp thích hợp quyền sở hữu:
Mã:
sudo chown -R nginx:nginx /var/www/pagekit
Chạy sudo vim /etc/php-fpm.d/www.conf và đặt người dùng và nhóm thành nginx. Ban đầu, chúng sẽ được đặt thành apache:
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
Điều hướng đến thư mục mà bạn đã tải Bolt CMS lên trong trình duyệt web của mình và làm theohướng dẫn trên màn hình.

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

Mở trang web của bạn trong trình duyệt web và bạn sẽ thấy trang sau:



Nhấp vào biểu tượng mũi tên phải để tiếp tục cài đặt. Chọn ngôn ngữ của bạn và nhấp vào nút "Tiếp theo":



Tiếp theo, chọn cơ sở dữ liệu SQLite hoặc MySQL và điền vào các trường bắt buộc và nhấp vào nút "Tiếp theo":





Sau đó, thiết lập trang web của bạn bằng cách nhập Tiêu đề trang web và tạo tài khoản người dùng quản trị:



Và thế là xong. Bạn sẽ được chuyển hướng đến trang đăng nhập Pagekit. Cung cấp tên người dùng và mật khẩu của bạn để đăng nhập vào bảng điều khiển Pagekit.



Vậy là xong. Nếu bạn gặp khó khăn, hãy xem tài liệu chính thức của Pagekit.

Liên kết​

 
Back
Bên trên