如何在FreeBSD 12上安装Vanilla论坛

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

香草 是一个用PHP编写的简单讨论论坛。 Vanilla源代码公开托管在 Github。本指南将引导您在使用PHP,MariaDB作为数据库以及Nginx作为Web服务器的全新FreeBSD 12 Vultr服务器实例上完成Vanilla安装过程。

要求

香草论坛推荐的软件堆栈:

PHP 7.2或更高版本,具有以下扩展名:

mbstring
curl
gd
PDO
mysqli
openssl

MySQL 5.7或更高版本,或等效的MariaDB。本指南将使用MariaDB
Web服务器软件,例如Nginx或Apache。本指南将使用Nginx
SSL加密是可选的,但建议使用

在你开始之前

检查FreeBSD版本。

uname -ro
# FreeBSD 12.0-RELEASE

确保您的FreeBSD系统是最新的。

freebsd-update fetch install
pkg update && pkg upgrade -y

如果系统上不存在一些基本的系统管理软件包,请安装它们。

pkg install -y sudo vim unzip wget curl bash socat git unzip

使用您的首选用户名创建一个新用户帐户(我们将使用 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-curl php72-gd php72-pdo php72-mysqli php72-pdo_mysql php72-json php72-openssl php72-ctype php72-dom php72-hash php72-iconv php72-tokenizer php72-calendar php72-fileinfo php72-session php72-simplexml php72-xml php72-filter

检查版本。

php --version
# PHP 7.2.14 (cli) (built: Jan 15 2019 01:14:39) ( 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扩展。

php -m
# mbstring
# curl
# gd
# PDO
# mysqli
# openssl
# . . .

启用并启动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.19-MariaDB, for FreeBSD12.0 (amd64) using readline 5.1

启动并启用MariaDB。

sudo sysrc mysql_enable="yes" 
sudo service mysql-server start

跑过 mysql_secure_installation 脚本以提高安装的安全性。

sudo mysql_secure_installation

以root用户身份登录MariaDB。

mysql -u root -p
# Enter password:

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

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

安装Nginx

安装Nginx。

sudo pkg install -y nginx

检查版本。

nginx -v
# nginx version: nginx/1.14.2

启用并启动Nginx。

sudo sysrc nginx_enable=yes
sudo service nginx start

配置Nginx以与Vanilla论坛一起使用。

sudo vim /usr/local/etc/nginx/vanilla.conf

用以下内容填充文件。

server {

  listen 80;
  server_name example.com;
  root /usr/local/www/vanilla;
  index index.php;

  location ~* /.git { deny all; return 403; }
  location /build/ { deny all; return 403; }
  location /cache/ { deny all; return 403; }
  location /cgi-bin/ { deny all; return 403; }
  location /image/import/ { deny all; return 403; }
  location /conf/ { deny all; return 403; }
  location /tests/ { deny all; return 403; }
  location /vendor/ { deny all; return 403; }

  location ~* ^/index.php(/|$) {
    fastcgi_split_path_info ^(.+.php)(/.+)$;
    try_files $fastcgi_script_name =404;
    set $path_info $fastcgi_path_info;
    fastcgi_param PATH_INFO $path_info;
    fastcgi_index index.php;
    include fastcgi_params;
    fastcgi_param SCRIPT_NAME /index.php;
    fastcgi_param SCRIPT_FILENAME $realpath_root/index.php;
    fastcgi_param X_REWRITE 1;
    fastcgi_pass 127.0.0.1:9000;
  }

  location ~* .php(/|$) {
    rewrite ^ /index.php$uri last;
  }

  location / {
    try_files $uri $uri/ @vanilla;
  }

  location @vanilla {
    rewrite ^ /index.php$uri last;
  }

}

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

现在我们需要包括 vanilla.conf 主文件 nginx.conf 文件。

sudo vim /usr/local/etc/nginx/nginx.conf 并将以下行添加到 http {} 块。

include vanilla.conf;

测试配置。

sudo nginx -t

重新加载Nginx。

sudo service nginx reload

安装香草论坛

创建一个文档根目录。

sudo mkdir -p /usr/local/www/vanilla

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

sudo chown -R johndoe:johndoe /usr/local/www/vanilla

导航到文档根目录。

cd /usr/local/www/vanilla

下载 最新的香草论坛

wget https://open.vanillaforums.com/get/vanilla-core-2.6.4.zip

解压缩并删除压缩文件。

unzip vanilla-core-2.6.4.zip
rm vanilla-core-2.6.4.zip

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

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

重新启动PHP-FPM。

sudo service php-fpm restart

在网络浏览器中导航到上载Vanilla的文件夹,然后按照屏幕上的说明完成设置。

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