PyroCMS là một CMS mã nguồn mở, mạnh mẽ,mô-đun và nền tảng phát triển được xây dựng bằng Laravel 5, cho phép bạn xây dựng các trang web và ứng dụng Laravel tốt hơn, nhanh hơn.
Trong hướng dẫn này, chúng tôi sẽ hướng dẫn bạn quy trình cài đặt PyroCMS trên hệ điều hành Debian 9 (stretch)bằng cách sử dụngNGINX 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à cơ quan cấp 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 Debian:
Để 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:
Dịch vụ PHP-FPM được tự động khởi động và bật khi khởi động lại trên hệ thống Debian 9, do đó không cần phải khởi động và bật 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.
Kiểm tra phiên bản 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 PyroCMS 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ỉ, hãy 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:
Cấu hìnhNGINX cho PyroCMS bằng cách chạy:
Và điền cấu hình sau vào tệp:
Kích hoạt cấu hình
Kiểm tra cấu hìnhNGINX để tìm lỗi cú pháp:
Tải lại dịch vụNGINX:
Kiểm tra phiên bản Composer:
Thay đổi quyền sở hữu 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 PyroCMS qua
Thay đổi quyền sở hữu thư mục
Sau khi bạn đã điền đầy đủ thông tin bắt buộc, quá trình cài đặt PyroCMS của bạn đã hoàn tất.
Trong hướng dẫn này, chúng tôi sẽ hướng dẫn bạn quy trình cài đặt PyroCMS trên hệ điều hành Debian 9 (stretch)bằng cách sử dụngNGINX 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à cơ quan cấp chứng chỉ Let's Encrypt để thêm hỗ trợ SSL.
Yêu cầu
Để cài đặt PyroCMS, hãy đảm bảo hệ thống của bạn đáp ứng các yêu cầu sau:- Ít nhất 1GB RAM hoặc Swap đã cấu hình
- Phiên bản PHP 7.0 trở lên vớiPDO,cURL,SQLite,OpenSSL,Mbstring,Fileinfo,Tokenizer, tiện ích mở rộng GD PHP.
- MariaDB
- NGINX
Điều kiện tiên quyết
- Một hệ thống chạy Debian 9 (stretch).
- 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 Debian của bạn:
Mã:
lsb_release -ds
# Debian GNU/Linux 9.7 (stretch)
Mã:
dpkg-reconfigure tzdata
Mã:
apt update && apt upgrade -y
Mã:
apt install -y curl wget vim gitsudo unzip socat bash-completion dirmngr apt-transport-https
Bước 1 - Cài đặt PHP và các tiện ích mở rộng PHP cần thiết
Tải xuống và cài đặt PHP 7.0 và các tiện ích mở rộng PHP cần thiết:
Mã:
sudo apt install -y php7.0 php7.0-cli php7.0-fpm php7.0-mysql php7.0-curl php7.0-sqlite3 php7.0-mbstring php7.0-gd php7.0-xml
Mã:
php -m
ctype
curl
exif
thông tin tệp
. . .
. . .
Mã:
php --version
# PHP 7.0.33-0+deb9u1 (cli) (xây dựng: 7 tháng 12 năm 2018 11:36:49) ( NTS )
# Bản quyền (c) 1997-2017 The PHP Group
# Zend Engine v3.0.0, Bản quyền (c) 1998-2017 Zend Technologies
# với Zend OPcache v7.0.33-0+deb9u1, Bản quyền (c) 1999-2017, của Zend Technologies
Bước 2 - Cài đặtMariaDB và tạo cơ sở dữ liệu cho PyroCMS
Cài đặtMariaDB:
Mã:
sudo apt install -y mariadb-server
Mã:
mysql --version
#mysql Ver 15.1 Distrib 10.1.37-MariaDB, dành cho debian-linux-gnu (x86_64) bằng readline 5.2
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 cho 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 Acme.sh client 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 Acme.sh client. 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ỉ, hãy 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 PyroCMS
Cài đặt máy chủ web NGINX:
Mã:
sudo apt install -y nginx
Mã:
sudo nginx -v
# phiên bản nginx: nginx/1.10.3
Mã:
sudo vim /etc/nginx/sites-available/pyro.conf
Mã:
server { listen 80; listen 443 ssl;
server_name example.com;
index index.php index.html;
root /var/www/pyro/public;
location / {
try_files $uri $uri/ /index.php?$args;
}
rewrite ^/(.*)/$ /$1 permanent;
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
pyro.conf
mới bằng cách liên kết tệp đến sites-enabled
thư mục.
Mã:
sudo ln -s /etc/nginx/sites-available/pyro.conf /etc/nginx/sites-enabled
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 PyroCMS
Tạo thư mục gốc của tài liệu nơi PyroCMS sẽ nằm:
Mã:
sudo mkdir -p /var/www/pyro
/var/www/pyro
thành [your_user]:
Mã:
sudo chown -R [your_user]:[your_user] /var/www/pyro
Mã:
cd /var/www/pyro
composer
:
Mã:
composer create-project pyrocms/pyrocms .
/var/www/pyro
thành www-data
.
Mã:
sudo chown -R www-data:www-data /var/www/pyro
Bước 7 - Hoàn tất thiết lập PyroCMS
Truy cập trang web của bạn trong trình duyệt web thông qua tên miền hoặc địa chỉ IP và làm theo trình hướng dẫn cài đặt web PyroCMS.Sau khi bạn đã điền đầy đủ thông tin bắt buộc, quá trình cài đặt PyroCMS của bạn đã hoàn tất.