如何在FreeBSD 12上安装Flarum论坛

注:本教程在Vultr VPS上测试通过,如需部署请前往Vultr.com

Flarum 是一个免费的开放源代码的下一代论坛软件,使在线讨论变得有趣。 Flarum源代码托管在 Github。它被设计为快速,简单,响应迅速和可扩展的。

本指南将引导您在使用PHP,MariaDB作为数据库和Nginx作为Web服务器的全新FreeBSD 12.0 Vultr实例上,完成Flarum安装过程。

要求

在安装Flarum之前,重要的是要检查您的服务器是否符合要求。要运行Flarum,您将需要:

阿帕奇(与 mod_rewrite 启用)或Nginx。本指南将使用Nginx。
PHP 7.1或更高版本,带有以下PHP扩展: domgdJSONmbstringOpenSSLpdo_mysqltokenizer
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): 
# Login group [johndoe]: 
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: 
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: 
# Home directory permissions (Leave empty for default): 
# Use password-based authentication? [yes]: 
# Use an empty password? (yes/no) [no]: 
# Use a random password? (yes/no) [no]: 
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: 
# 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-productionphp.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

以root用户身份登录MariaDB。

mysql -u root -p
# Enter password:

创建一个新的MariaDB数据库和用户。记住该新用户的凭据。

CREATE DATABASE dbname;
GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
exit;

注意: 更换 dbnameusername 使用适合您的设置的名称。更换 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

为Flarum配置Nginx。跑 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;
  }

}

保存文件并使用:+ W + Q退出。

现在我们需要包括 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

注意: 通过Composer安装Flarum时,内存可能用完了。如果发生这种情况,则需要设置交换。

更改所有权 /usr/local/www/flarum 目录到 www

sudo chown -R www:www /usr/local/www/flarum

在网络浏览器中打开您的站点,然后按照屏幕上的说明完成安装。

注:本教程在Vultr VPS上测试通过,如需部署请前往Vultr.com