Bolt là một CMStinh vi, nhẹ và đơn giảnđược xây dựng bằng PHP. Nó đượcphát hành theo giấy phép MIT nguồn mở và mã nguồn được lưu trữ dưới dạng kho lưu trữ công khai trên Github. Bolt là một công cụ Quản lý nội dung, cố gắng đơn giản và dễ hiểu nhất có thể. Nó nhanh chóng thiết lập, dễ cấu hình, sử dụng các mẫu thanh lịch. Bolt được tạo ra bằng các thư viện mã nguồn mở hiện đại và phù hợp nhất để xây dựng các trang web trong HTML5 với mã đánh dấu hiện đại.Trong hướng dẫn này, chúng ta sẽ hướng dẫn cài đặt Bolt CMS trên hệ thống Fedora 29 bằ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 của hệ điều hành Fedora:
Để 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
Trả lời từng câu hỏi sau:
Kết nối đến shell MariaDB với tư cách là người dùng root:
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:
Thoát khỏi MariaDB:
Thay thế
Bước 3 - Cài đặt máy khách
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 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ỉ TLS từ Let's Encrypt mà không cần phụ thuộc.
Tải xuống và cài đặt acme.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
Sau khi chạy các lệnh trên, chứng chỉvàkhóacủa bạn sẽ nằm trong:
Tạo các 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.
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:
Tải xuống và cài đặt Nginx từ kho lưu trữ Fedora:
Kiểm tra phiên bản Nginx:
Khởi động và bật dịch vụ Nginx:
Cấu hình Nginx cho Bolt CMS bằng cách chạy:
Và điền vào tệp với cấu hình sau:
LƯU Ý: Để biết cấu hình Nginx hoàn chỉnh và sẵn sàng cho sản xuất cho BoltCMS, hãy xemhttps://docs.bolt.cm/3.6/installation/webserver/nginx.
Kiểm tra cấu hình Nginx để tìm lỗi cú pháp:
Tải lại dịch vụ Nginx:
Điều hướng đến thư mục
Tải xuống phiên bản mới nhất của Bolt CMS qua wget và giải nén:
Xóa tệp
Đổi tên thư mục bolt-v3.6.4 thành bolt:
Đổi thư mục thành thư mục gốc của tài liệu:
Để hoàn tất quá trình cài đặt, bạn sẽ cần đổi tên các tệp sau:
Cung cấp quyền sở hữu phù hợp:
Chạy
Khởi động lại dịch vụ PHP-FPM:
Đ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.
Điền thông tin bắt buộc để tạo người dùng và nhấp vào nút "Tạo người dùng đầu tiên" để tiếp tục. Sau đó, giao diện Bolt CMSadmin sẽ hiển thị:
Cài đặt Bolt CMS hiện đã hoàn tất. Để truy cập Bolt CMS admin, hãy thêm
Yêu cầu
Yêu cầu hệ thống đối với Bolt khá khiêm tốn và có thể chạy trên bất kỳ máy chủ web hiện đại nào:- Phiên bản PHP 5.5.9 trở lên với các phần mở rộng PHP phổ biến sau: pdo, mysqlnd, pgsql, openssl, curl, gd, intl, json, mbstring, opcache, posix, xml, fileinfo, exif, zip.
- Truy cập vào SQLite (đi kèm với PHP), hoặc MySQL hoặc PostgreSQL.
- Apache với
mod_rewrite
được bật (tệp.htaccess
) hoặc Nginx (cấu hình máy chủ ảo được đề cập bên dưới). - Tối thiểu 32MB bộ nhớ được phân bổ cho PHP.
Điều kiện tiên quyết
- Hệ điều hành chạy Fedora 29.
- 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 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 check-update; sudo dnf update -y
Mã:
sudo dnf install -y curl wget vim gitunzip socat bash-completion
Bước 1 - Cài đặt PHP và các tiện ích mở rộng PHP cần thiết
Cài đặt PHP cũng như 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-pgsql php-sqlite3 php-curl php-gd php-mysqlnd php-intl php-json php-opcache php-xml php-process
Mã:
php -m
ctype
curl
exif
thông tin tệp
. . .
. . .
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 cho Bolt CMS
Bolt CMS hỗ trợ cơ sở dữ liệu MySQL, MariaDB và PostgreSQL. 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
#mysql Ver 15.1 Distrib 10.3.11-MariaDB, dành cho Linux (x86_64) bằng readline 5.1
Mã:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
mysql_secure installation
script để cải thiện bảo mật MariaDB và đặt mật khẩu cho MariaDB root
user:
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
, tên người dùng
và mật khẩu
bằng tên của 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ỉ TLS 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ỉ TLS từ Let's Encrypt mà không cần phụ thuộc.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.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
flage 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ẽ nằm trong:
- Đối với RSA: thư mục
/home/username/example.com
. - Đối với ECC/ECDSA: thư mục
/home/username/example.com_ecc
.
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 NGINX và cấu hình NGINX cho Bolt CMS
BoltCMS có thể hoạt động tốt với nhiều phần mềm máy chủ web phổ biến. 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 xem https://docs.bolt.cm/3.6/installation/webserver/apache để tìm hiểu thêm.Tải xuống và cài đặt Nginx từ kho lưu trữ Fedora:
Mã:
sudo dnf install -y nginx
Mã:
nginx -v
#nginx version: nginx/1.14.1
Mã:
sudo systemctl start nginx.service
sudo systemctl enable nginx.service
Mã:
sudo vim /etc/nginx/conf.d/bolt.conf
Mã:
máy chủ {
lắng nghe 80;
lắng nghe 443 ssl http2;
tên máy chủ example.com;
gốc /var/www/bolt/public;
chỉ mục index.php;
# RSA
chứng chỉ ssl /etc/letsencrypt/example.com/fullchain.pem;
khóa chứng chỉ ssl /etc/letsencrypt/example.com/private.key;
# ECC
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í / {
tệp_thử $uri $uri/ /index.php?$query_string;
}
location = /bolt {
try_files $uri /index.php?$query_string;
}
location ^~ /bolt/ {
try_files $uri /index.php?$query_string;
}
location ~ /index.php/(.*) {
viết lại ^/index.php/(.*) /$1 vĩnh viễn;
}
location ~ /\. { từ chối tất cả; }
location ~ /\.(htaccess|htpasswd)$ { từ chối tất cả; }
location ~ /\.(?:db)$ { từ chối tất cả; }
location ~* /(.*)\.(?:markdown|md|twig|yaml|yml)$ { từ chối tất cả; }
location ~ [^/]\.php(/|$) {
include default.d/php.conf;
fastcgi_split_path_info ^(.+?\.php)(/.*)$;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param HTTP_PROXY "";
fastcgi_param HTTPS $https if_not_empty;
fastcgi_pass unix:/run/php-fpm/www.sock;
}
}
Kiểm tra cấu hình Nginx để tìm lỗi cú pháp:
Mã:
sudo nginx -t
Mã:
sudo systemctl reload nginx.service
Bước 5 - Cài đặt CMS Bolt
Tạo thư mục /var/www[/ICODE]:
Mã:
sudo mkdir -p /var/www/
/var/www
:
Mã:
cd /var/www/
Mã:
sudo wget https://bolt.cm/distribution/bolt-latest.zip && sudo unzip bolt-latest.zip
bolt-latest.zip
đã tải xuống:
Mã:
sudo rm bolt-latest.zip
Mã:
sudo mv bolt-v3.6.4 bolt
Mã:
cd /var/www/bolt
Mã:
sudo mv .bolt.yml.dist .bolt.yml
sudo mv composer.json.dist composer.json
sudo mv composer.lock.dist composer.lock
sudo mv src/Site/CustomisationExtension.php.dist src/Site/CustomisationExtension.php
Mã:
sudo chown -R nginx:nginx /var/www/bolt
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 cài đặt và thiết lập Bolt CMS
Sau khi mở trang web của bạn trong trình duyệt web, bạn sẽ được chuyển hướng đến trang sau:Điền thông tin bắt buộc để tạo người dùng và nhấp vào nút "Tạo người dùng đầu tiên" để tiếp tục. Sau đó, giao diện Bolt CMSadmin sẽ hiển thị:
Cài đặt Bolt CMS hiện đã hoàn tất. Để truy cập Bolt CMS admin, hãy thêm
/bolt
vào IP hoặc tên miền của trang web của bạn.