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ệ thống 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 Fedora 29bằ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.
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 hệ điều hành Fedora:
Tải xuống và cài đặt PHP và các tiện ích mở rộng PHP cần thiết:
Để 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 cơ sở dữ liệu và thiết lập.
Cài đặt máy chủ cơ sở dữ liệu MariaDB:
Kiểm tra phiên bản MariaDB:
Khởi động và kích hoạt dịch vụ MariaDB:
Chạy tập lệnh
Trả lời từng câu hỏi sau:
Đăng nhập vào MariaDB với tư cách là người dùng root:
Tạo cơ sở dữ liệu MariaDB và người dùng mà bạn sẽ sử dụng để cài đặt Pagekit và ghi nhớ thông tin đăng nhập:
Thoát khỏi shell MariaDB:
Tải xuống và cài đặtacme.sh:
Kiểm tra phiên bản acme.sh:
Lấy chứng chỉ RSA và ECC/ECDSA cho tên miền/tên máy chủ của bạn:
Nếu bạn muốn có chứng chỉ giả để thử nghiệm, bạn có thể thêm
Để liệt kê các chứng chỉ đã cấp, bạn có thể chạy:
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/letsencryptthư mục.
Sau khi chạy các lệnh trên, chứng chỉvà khóacủa bạn sẽ nằm trong:
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:
Kiểm tra phiên bản NGINX:
Khởi động và kích hoạt dịch vụ Nginx:
Cấu hìnhNGINX cho Pagekit bằng cách chạy:
Và điền cấu hình sau vào tệp:
Kiểm tra cấu hìnhNGINX để tìm lỗi cú pháp:
Tải lại dịch vụNGINX:
Thay đổi quyền sở hữu của thư mục
Điều hướng đến thư mục gốc của tài liệu:
Tải xuống bản phát hành ổn định mới nhất của Pagekit CMS qua
Giải nén nội dung CMS Pagekit và xóa tệp
Cung cấp quyền sở hữu phù hợp:
Chạy
Khởi động lại dịch vụ PHP-FPM:
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 của bạn là 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.
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 Fedora 29bằ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 chạy Fedora 29.
- 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 hệ thống Fedora của bạn:
Mã:
cat /etc/fedora-release
# Fedora phát hành 29 (Hai mươi chín)
Mã:
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Mã:
sudo dnf upgrade -y
Mã:
sudo dnf install -y curl wget vim gitsudo unzip socat bash-completion
Bước 1 - Cài đặt PHP và các tiện ích mở rộng PHP cần thiết
Nền tảng PagekitCMS yêu cầu PHP phiên bản 7.0 trở lên. Fedora 29 có phiên bản PHP 7.2 trong kho lưu trữ mặc định của nó.Tải xuống và cài đặt PHP và các tiện ích mở rộng PHP cần thiết:
Mã:
sudo dnf install -y php-cli php-fpm php-common php-mbstring php-zip php-mysqlnd php-sqlite3 php-curl php-xml php-json
Mã:
php -m
ctype
curl
exif
fileinfo
. . .
. . .
Mã:
php --version
#PHP 7.2.14 (cli) (được xây dựng: 8 tháng 1 năm 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
# với Zend OPcache v7.2.14, Bản quyền (c) 1999-2018, của Zend Technologies
Mã:
sudo systemctl start php-fpm.service
sudo systemctl enable php-fpm.service
Bước 2 - Cài đặtMariaDB và tạo cơ sở dữ liệu choPagekit
Pagekit CMS hỗ trợ cơ sở dữ liệu MySQL, MariaDB và SQLite. 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
Mã:
mysql --version
Mã:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
mysql_secure installation
để cải thiện bảo mật MariaDB và đặt mật khẩu cho người dùng root
MariaDB:
Mã:
sudo mysql_secure_installation
Mã:
Nhập mật khẩu hiện tại đối với root (enter nếu không có): [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 root đăng nhập 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ã:
CREATE DATABASE dbname;
GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
Mã:
quit
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 vệ 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 ~
Mã:
acme.sh --version
# v2.8.1
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.Để liệt kê các chứng chỉ đã cấp, bạn có thể chạy:
Mã:
acme.sh --list
/etc/letsencrypt
.
Mã:
mkdir -p /etc/letsencrypt/example.com
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"
- Đối với RSA:/etc/letsencrypt
/example.com
thư mục. - Đối với ECC/ECDSA:/etc/letsencrypt
/example.com_ecc
thư mục.
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
Cài đặt máy chủ web NGINX:
Mã:
sudo dnf install -y nginx
Mã:
nginx -v
# phiên bản nginx: nginx/1.14.1
Mã:
sudo systemctl start nginx.service
sudo systemctl enable nginx.service
Mã:
sudo vim /etc/nginx/conf.d/pagekit.conf
Mã:
server {
listen [::]:443 ssl http2;
listen 443 ssl http2; listen [::]:80; listen 80; server_name example.com; index 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; }
location ~ \.php$ {
include default.d/php.conf;
fastcgi_pass unix:/run/php-fpm/www.sock;
}}
Mã:
sudo nginx -t
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
/var/www/pagekit
thành [your_user]:
Mã:
sudo chown -R [your_user]:[your_user] /var/www/pagekit
Mã:
cd /var/www/pagekit
wget
:
Mã:
wget https://github.com/pagekit/pagekit/releases/download/1.0.16/pagekit-1.0.16.zip
.zip
đã tải xuống.
Mã:
giải nén pagekit-1.0.16.zip
rm pagekit-1.0.16.zip
Mã:
sudo chown -R nginx:nginx /var/www/pagekit
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
Mã:
sudo systemctl restart php-fpm.service
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 của bạn là 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.