Anchorlà một CMS blog mã nguồn mở nhẹ được viết bằng PHP. Mã nguồn của Anchor được lưu trữ trên GitHub. Trong hướng dẫn này, chúng ta sẽ cài đặt Anchor CMS bằng PHP, Nginx, MariaDB và Composer trên hệ thống FreeBSD 12.
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 FreeBSD 12.0:
Cài đặt PHP cũng như 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 và thiết lập cơ sở dữ liệu.
Cài đặt 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ất cả các câu hỏi như hiển thị bên dưới:
Đăng nhập vào shell 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 Anchor CMS và ghi nhớ thông tin đăng nhập:
Thoát khỏi shell 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ỉ 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 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ở về người dùng sudo bình thường:
Kiểm tra phiên bảnNGINX:
Khởi động và kích hoạt dịch vụNGINX:
Cấu hình Nginx cho Anchor CMS bằng cách chạy:
Và điền vào tệp với cấu hình sau:
Chạy
Kiểm tra cấu hình Nginx xem có lỗi cú pháp không:
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
LƯU Ý: Thay thế bằng 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:
Tải xuốngphiên bản mới nhất của Anchor CMS bằng Composer:
Thay đổi quyền sở hữu thư mục
Nhấp vào nút "Chạy trình cài đặt" để khởi chạy trình cài đặt web Anchor CMS. Sau đó, trang ngôn ngữ và múi giờ sẽ xuất hiện:
Chọn cài đặt bạn muốn và nhấp vào nút "Bước tiếp theo" để chuyển đến trang cấu hình cơ sở dữ liệu:
Nhập thông tin chi tiết về cơ sở dữ liệu của bạn và nhấp vào nút "Bước tiếp theo" để chuyển đến trang cấu hình siêu dữ liệu của trang web:
Bạn có thể đặt tên trang web hoặc mô tả trang web tại đây hoặc giữ nguyên mặc định và thay đổi sau thông qua giao diện phụ trợ Anchor. Nhấp vào nút "Bước tiếp theo" để đến bước tiếp theo là thiết lập tài khoản đầu tiên của bạn:
Sau khi thiết lập tài khoản đầu tiên, hãy nhấp vào nút "Hoàn tất" để hoàn tất quá trình cài đặt.
Sau khi hoàn tất quá trình cài đặt, hãy đảm bảo xóa thư mục install vì mục đích bảo mật.
Yêu cầu
Đảm bảo hệ thống của bạn đáp ứng các yêu cầu sau.- MySQL 5.6 trở lên (khuyến nghị MySQL 5.7).
- PHP 5.6 trở lên với các phần mở rộng PHP sau: (
curl,
mcrypt,
gd,
mbstring,
pdo_mysql
hoặcpdo_sqlite
). - Apache hoặc Nginx. Trong hướng dẫn này, chúng ta sẽ sử dụng Nginx.
Điều kiện tiên quyết
- Hệ điều hành FreeBSD 12.
- 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 FreeBSD của bạn:
Mã:
uname -ro
# FreeBSD 12.0-RELEASE
Mã:
tzsetup
Mã:
freebsd-update fetch install
pkg update && pkg upgrade -y
Mã:
pkg install -y sudo vim unzip wget bash socat
Bước 1 - Cài đặt PHP
Anchor CMS yêu cầu phiên bản PHP5.6hoặc cao hơn.Cài đặt PHP cũng như các tiện ích mở rộng PHP cần thiết:
Mã:
sudo pkg install -y php72 php72-mbstring php72-tokenizer php72-pdo php72-pdo_mysql php72-openssl php72-hash php72-json php72-phar php72-filter php72-zlib php72-dom php72-xml php72-xmlwriter php72-xmlreader php72-curl php72-session php72-ctype php72-iconv php72-gd php72-simplexml php72-zip php72-filter php72-tokenizer php72-calendar php72-fileinfo php72-intl php72-phar php72-soap php72-xmlrpc
Mã:
php -m
ctype
curl
exif
fileinfo
. . .
. . .
Mã:
php --version
#PHP 7.2.12 (cli) (được xây dựng: 11 tháng 11 năm 2018 14:54:16) ( 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
Mã:
sudo sysrc php_fpm_enable=yes
sudo service php-fpm start
Bước 2 - Cài đặt MariaDB và tạo cơ sở dữ liệu forAnchor CMS
Anchor hỗ trợ cơ sở dữ liệu MySQL/MariaDB và SQLite. Trong hướng dẫn này, chúng ta sẽ sử dụngMariaDB làm máy chủ cơ sở dữ liệu.Cài đặt MariaDB:
Mã:
sudo pkg install -y mariadb102-client mariadb102-server
Mã:
mysql --version
# mysql Ver 15.1 Distrib 10.2.19-MariaDB, dành cho Linux (x86_64) bằng readline 5.1
Mã:
sudo sysrc mysql_enable="yes"
sudo service mysql-server start
mysql_secure installation
để cải thiện bảo mật MariaDB và thiết lập 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 (nhập nếu không nhập):
Đặt mật khẩu root? [Y/n]: Y
Xóa người dùng ẩn danh? [Y/n]: Y
Không cho phép root đăng nhập từ xa? [Y/n]: Y
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]: Y
Tải lại bảng đặc quyền ngay bây giờ? [Y/n]: Y
Mã:
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
dbname
, username
và password
bằng tên của bạn.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ỉ TLS 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ỉ 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 pkg install acme.sh
Mã:
acme.sh --version
# v2.8.4
Mã:
# RSA 2048
acme.sh --issue--standalone -d example.com --keylength 2048
# ECDSA
acme.sh --issue --standalone -d example.com --keylength ec-256
--staging
cờ cho 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ở về người dùng sudo bình thường:
Mã:
exit
Bước 4 - Cài đặt và cấu hình NGINX
Cài đặt máy chủ web NGINX:
Mã:
sudo pkg install -y nginx
Mã:
nginx -v
# phiên bản nginx: nginx/1.14.2
Mã:
sudo sysrc nginx_enable=yes
sudo service nginx start
Mã:
sudo vim /usr/local/etc/nginx/anchor.conf
Mã:
server { listen 80;
listen 443 ssl;
ssl_certificate /etc/letsencrypt/status.example.com/fullchain.pem;
khóa_chứng_nhận_ssl /etc/letsencrypt/status.example.com/private.key;
khóa_chứng_nhận_ssl /etc/letsencrypt/status.example.com_ecc/fullchain.pem;
khóa_chứng_nhận_ssl /etc/letsencrypt/status.example.com_ecc/private.key; tên_máy_chủ example.com; gốc /var/www/anchor; chỉ mục index.php index.html; vị trí / { try_files $uri $uri/ /index.php; } vị trí ~ \.php$ { try_files $uri =404; bao gồm fastcgi_params; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; }}
sudo vim /usr/local/etc/nginx/nginx.conf
và thêm dòng bên dưới vào khối http {}
để includeAnchor config.
Mã:
include anchor.conf;
Mã:
sudo nginx -t
Mã:
sudo service nginx reload
Bước 5 - Tải xuống và cài đặt Composer
Để cài đặt Anchor thành công, chúng ta sẽ cần cài đặt Composer, trình quản lý phụ thuộc cho các ứng dụng PHP:
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 - Tải xuống và cài đặt Anchor CMS
Tạo thư mục gốc của tài liệu nơi Anchor sẽ lưu trú:
Mã:
sudo mkdir -p /usr/local/www/anchor
/usr/local/www/anchor
thành {jour_user}:
Mã:
sudo chown -R your_user:your_user /usr/local/www/anchor
Điều hướng đến thư mục gốc của tài liệu:
Mã:
cd /usr/local/www/anchor
Mã:
composer create-project anchorcms/anchor-cms .
/usr/local/www/anchor
thành www:
Mã:
sudo chown -R www:www /usr/local/www/anchor
Bước 7 - Hoàn tất Anchor CMSsetup
Mở trình duyệt web của bạn và nhập URL"http://example.com". Bạn sẽ được chuyển hướng đến trang sau:Nhấp vào nút "Chạy trình cài đặt" để khởi chạy trình cài đặt web Anchor CMS. Sau đó, trang ngôn ngữ và múi giờ sẽ xuất hiện:
Chọn cài đặt bạn muốn và nhấp vào nút "Bước tiếp theo" để chuyển đến trang cấu hình cơ sở dữ liệu:
Nhập thông tin chi tiết về cơ sở dữ liệu của bạn và nhấp vào nút "Bước tiếp theo" để chuyển đến trang cấu hình siêu dữ liệu của trang web:
Bạn có thể đặt tên trang web hoặc mô tả trang web tại đây hoặc giữ nguyên mặc định và thay đổi sau thông qua giao diện phụ trợ Anchor. Nhấp vào nút "Bước tiếp theo" để đến bước tiếp theo là thiết lập tài khoản đầu tiên của bạn:
Sau khi thiết lập tài khoản đầu tiên, hãy nhấp vào nút "Hoàn tất" để hoàn tất quá trình cài đặt.
Sau khi hoàn tất quá trình cài đặt, hãy đảm bảo xóa thư mục install vì mục đích bảo mật.
Mã:
sudo rm -rf /var/www/anchor/install