Flarumเป็นซอฟต์แวร์ฟอรัมรุ่นใหม่ฟรีและโอเพนซอร์สที่ทำให้การสนทนาออนไลน์เป็นเรื่องสนุก รหัสที่มา Flarum โฮสต์บนGithub มันถูกออกแบบมาให้รวดเร็วง่ายตอบสนองและยืดขยายได้
คู่มือนี้จะแนะนำคุณเกี่ยวกับกระบวนการติดตั้ง Flarum บนอินสแตนซ์ FreeBSD 12.0 Vultr ใหม่โดยใช้ PHP, MariaDB เป็นฐานข้อมูลและ Nginx เป็นเว็บเซิร์ฟเวอร์
ความต้องการ
ก่อนที่คุณจะติดตั้ง Flarum คุณจำเป็นต้องตรวจสอบว่าเซิร์ฟเวอร์ของคุณตรงตามข้อกำหนดหรือไม่ ในการใช้งาน Flarum คุณจะต้อง:
- Apache (พร้อม
mod_rewrite
เปิดใช้งาน) หรือ Nginx คำแนะนำนี้จะใช้ Nginx
- PHP รุ่น 7.1 หรือสูงกว่าที่มีส่วนขยาย PHP ต่อไปนี้:
dom
, gd
, JSON
, mbstring
, OpenSSL
, ,pdo_mysql
tokenizer
- MySQL เวอร์ชั่น 5.6 หรือสูงกว่าหรือ MariaDB เวอร์ชัน 10.0.5 หรือสูงกว่า คู่มือนี้จะใช้ MariaDB
ก่อนที่จะเริ่ม
ตรวจสอบเวอร์ชั่น FreeBSD
uname -ro
# FreeBSD 12.0-RELEASE-p6
ตรวจสอบให้แน่ใจว่าระบบ FreeBSD ของคุณทันสมัย
freebsd-update fetch install
pkg update && pkg upgrade -y
ติดตั้งแพ็คเกจที่จำเป็น
pkg install -y sudo vim unzip curl wget bash socat git
สร้างบัญชีผู้ใช้ใหม่ด้วยชื่อผู้ใช้ที่คุณต้องการ johndoe
เราจะใช้
adduser
# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!
รันvisudo
คำสั่งและยกเลิกหมายเหตุ%wheel ALL=(ALL) ALL
บรรทัดเพื่ออนุญาตให้สมาชิกของwheel
กลุ่มเรียกใช้งานคำสั่งใด ๆ
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
su
ตอนนี้เปลี่ยนไปใช้ที่สร้างขึ้นใหม่ของคุณด้วย
su - johndoe
หมายเหตุ: แทนที่johndoe
ด้วยชื่อผู้ใช้ของคุณ
ตั้งค่าเขตเวลา
sudo tzsetup
ติดตั้ง PHP
ติดตั้ง PHP รวมถึงส่วนขยาย PHP ที่จำเป็น
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
ตรวจสอบเวอร์ชั่น
php --version
# PHP 7.2.21 (cli) (built: Aug 4 2019 01:12:37) ( NTS )
# Copyright (c) 1997-2018 The PHP Group
# Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
ซอฟท์เชื่อมโยงไปยังphp.ini-production
php.ini
sudo ln -s /usr/local/etc/php.ini-production /usr/local/etc/php.ini
เปิดใช้งานและเริ่ม PHP-FPM
sudo sysrc php_fpm_enable=yes
sudo service php-fpm start
ติดตั้ง MariaDB
ติดตั้ง MariaDB
sudo pkg install -y mariadb102-client mariadb102-server
ตรวจสอบเวอร์ชั่น
mysql --version
# mysql Ver 15.1 Distrib 10.2.25-MariaDB, for FreeBSD12.0 (amd64) using readline 5.1
เริ่มและเปิดใช้งาน MariaDB
sudo sysrc mysql_enable="yes"
sudo service mysql-server start
เรียกใช้mysql_secure_installation
สคริปต์เพื่อปรับปรุงความปลอดภัยของการติดตั้ง MariaDB ของคุณ
sudo mysql_secure_installation
ล็อกอินเข้าสู่ MariaDB ในฐานะผู้ใช้รูท
mysql -u root -p
# Enter password:
สร้างฐานข้อมูลและผู้ใช้ใหม่ของ MariaDB จำข้อมูลประจำตัวสำหรับผู้ใช้ใหม่นี้
CREATE DATABASE dbname;
GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
exit;
หมายเหตุ: แทนที่dbname
และusername
ด้วยชื่อที่เหมาะสมสำหรับการตั้งค่าของคุณ แทนที่password
ด้วยรหัสผ่านที่คาดเดายาก
ติดตั้ง Nginx
ติดตั้ง Nginx
sudo pkg install -y nginx
ตรวจสอบเวอร์ชั่น
nginx -v
# nginx version: nginx/1.16.0
เปิดใช้งานและเริ่ม Nginx
sudo sysrc nginx_enable=yes
sudo service nginx start
กำหนดค่า Nginx สำหรับ Flarum รันsudo vim /usr/local/etc/nginx/flarum.conf
และเติมไฟล์ด้วยการกำหนดค่าต่อไปนี้
server {
listen [::]:80;
listen 80;
server_name example.com;
root /usr/local/www/flarum/public;
index index.php;
location / {
try_files $uri $uri/ /index.php?$query_string;
}
location ~* \.php$ {
fastcgi_pass 127.0.0.1:9000;
include fastcgi_params;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
}
}
บันทึกไฟล์และออกด้วย:+ +WQ
ตอนนี้เราต้องรวมflarum.conf
ไว้ในnginx.conf
ไฟล์หลัก
เรียกใช้sudo vim /usr/local/etc/nginx/nginx.conf
และเพิ่มบรรทัดต่อไปนี้ในhttp {}
บล็อก
include flarum.conf;
ทดสอบการกำหนดค่า
sudo nginx -t
โหลดซ้ำ Nginx
sudo service nginx reload
ติดตั้งนักแต่งเพลง
ดาวน์โหลดและติดตั้ง Composer ผู้จัดการการพึ่งพาสำหรับ PHP
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === 'a5c698ffe4b8e849a443b120cd5ba38043260d5c4023dbf93e1558871f1f07f58274fc6f4c93bcfd858c6bd0775cd8d1') { echo 'Installer verified'; } else { echo 'Installer corrupt'; 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
ตรวจสอบเวอร์ชั่น
composer --version
# Composer version 1.9.0 2019-08-02 20:55:32
ติดตั้ง Flarum
หมายเหตุ: Flarum อยู่ในช่วงเบต้า ยังไม่แนะนำให้รันในการผลิตเว้นแต่คุณจะรู้ว่าคุณกำลังทำอะไรอยู่ คุณควรรอการปล่อยที่เสถียรสำหรับการใช้งานจริง
สร้างไดเรกทอรีรากของเอกสาร
sudo mkdir -p /usr/local/www/flarum
เปลี่ยนความเป็นเจ้าของของไดเรกทอรีไป/usr/local/www/flarum
johndoe
sudo chown -R johndoe:johndoe /usr/local/www/flarum
นำทางไปยังโฟลเดอร์รูทเอกสาร
cd /usr/local/www/flarum
ดาวน์โหลดรุ่นล่าสุดของ Flarum composer
ผ่าน
composer create-project flarum/flarum . --stability=beta
หมายเหตุ: คุณอาจมีหน่วยความจำไม่เพียงพอเมื่อติดตั้ง Flarum ผ่านตัวแต่งเพลง หากที่เกิดขึ้นแล้วคุณจะต้องตั้งค่า Swap
เปลี่ยนความเป็นเจ้าของของไดเรกทอรีไป/usr/local/www/flarum
www
sudo chown -R www:www /usr/local/www/flarum
เปิดไซต์ของคุณในเว็บเบราว์เซอร์และทำตามคำแนะนำบนหน้าจอเพื่อสิ้นสุดการติดตั้ง