Vanillaは、PHPで記述された無料のオープンソースディスカッションフォーラムです。 Vanilla Forumソフトウェアは、GNUGPL2ライセンスの下で配布されています。そのソースコードはGithubから入手できます。豊富なアドオンシステムがあり、Vanillaフォーラムにカスタム機能を追加するために利用できます。 Vanilla Forumのコンテンツは、Markdown言語を使用して作成できます。このチュートリアルでは、Nginxをウェブサーバーとして、MySQLをデータベースサーバーとして使用して、Fedora29システムでのVanillaForumのインストールとセットアップについて説明します。オプションで、acme.shクライアントとLet'sEncrypt認証局を使用してトランスポートレイヤーを保護できます。 SSLサポートを追加します。
Vanillaには、PHP、MySQL、およびWebサーバーソフトウェア(ApacheやNGINXなど)を備えたサーバーが必要です。ドメインを所有している必要があります。運用サーバーにインストールする場合は、DNSを使用してサーバーにドメインを構成済みですが、そうでない場合は、ドメインは必要ありません。
バニラフォーラム最小 要件は次のとおりです。
- PHPバージョン7.0以降。
- PHP拡張機能mbstring、cURL、GD、PDO、MySQLi、OpenSSL。
- MySQLバージョン5.0以降(またはPercona / MariaDBと同等のもの)。
- Webサーバーソフトウェア(Nginx、Apache ...)。
- MySQLの厳密モードが無効になっています。
バニラフォーラムを強くお勧めします :
- PHPバージョン7.2以降。
- PHP拡張機能mbstring、cURL、GD、PDO、MySQLi、OpenSSL。
- MySQLバージョン5.7以降(またはPercona / MariaDBと同等のもの)。
- Webサーバーソフトウェア(Nginx、Apache ...)。
- SSL暗号化。
注 : PHP 7.0はサポートが終了し、セキュリティパッチを受け取らないため、新しいバージョンのPHPを使用することを強くお勧めします。 バニラによるPHP7.0のサポートはまもなく終了します!
前提条件
- Fedora29を実行しているオペレーティングシステム。
- sudo権限を持つroot以外のユーザー。
Fedoraシステムのバージョンを確認してください:
cat /etc/fedora-release
# Fedora release 29 (Twenty Nine)
タイムゾーンを設定します:
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
オペレーティングシステムパッケージ(ソフトウェア)を更新します。これは、オペレーティングシステムのデフォルトのソフトウェアパッケージの最新の更新とセキュリティ修正を確実に行うための重要な最初のステップです。
sudo dnf upgrade -y
Fedoraオペレーティングシステムの基本的な管理に必要ないくつかの重要なパッケージをインストールします:
sudo dnf install -y curl wget vim git sudo zip unzip socat bash-completion
PHPと必要なPHP拡張機能をインストールします:
sudo dnf install -y php-cli php-fpm php-common php-mbstring php-curl php-gd php-mysqlnd php-json
モジュールにコンパイルされたPHPを表示するには、次のコマンドを実行できます。
php -m
ctype
curl
exif
fileinfo
. . .
. . .
PHPのバージョンを確認してください:
php --version
# PHP 7.2.16 (cli) (built: Mar 5 2019 11:05:59) ( NTS )
# Copyright (c) 1997-2018 The PHP Group
# Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
PHP-FPMサービスを開始して有効にします:
sudo systemctl start php-fpm.service
sudo systemctl enable php-fpm.service
次のステップであるデータベースのインストールとセットアップに進むことができます。
Vanilla Forumは、MySQL、MariaDB、およびPerconaデータベースをサポートしています。このチュートリアルでは、MariaDBをデータベースサーバーとして使用します。
次のコマンドを実行してMariaDBをインストールします:
sudo dnf install -y mariadb-server
MariaDBのバージョンを確認してください:
mysql --version
# mysql Ver 15.1 Distrib 10.3.12-MariaDB, for Linux (x86_64) using readline 5.1
MariaDBサービスを開始して有効にします:
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
mysql_secureインストール
を実行します MariaDBのセキュリティを向上させ、MariaDBの root
のパスワードを設定するスクリプト ユーザー:
sudo mysql_secure_installation
それぞれの質問に答えてください:
Enter current password for root (enter for none): Press Enter
Set root password? [Y/n] Y
New password: your_secure_password
Re-enter new password: your_secure_password
Remove anonymous users? [Y/n] Y
Disallow root login remotely? [Y/n] Y
Remove test database and access to it? [Y/n] Y
Reload privilege tables now? [Y/n] Y
rootユーザーとしてMariaDBシェルに接続します:
sudo mysql -u root -p
# Enter password
空のMariaDBデータベースとVanillaForumのユーザーを作成し、資格情報を覚えておいてください:
MariaDB [(none)]> CREATE DATABASE dbname;
MariaDB [(none)]> GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
MariaDB [(none)]> FLUSH PRIVILEGES;
MariaDBを終了します:
MariaDB [(none)]> exit
dbname
を置き換えます 、 username
およびpassword
自分の名前で。
acme.sh
をインストールします クライアントとLet'sEncrypt証明書を取得します(オプション ) HTTPSを使用してWebサイトを保護する必要はありませんが、サイトのトラフィックを保護することをお勧めします。 Let's EncryptからTLS証明書を取得するには、acme.shクライアントを使用します。 Acme.shは、依存関係がゼロのLet'sEncryptからTLS証明書を取得するための純粋なUNIXシェルソフトウェアです。
acme.shをダウンロードしてインストールします:
sudo su - root
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
./acme.sh --install --accountemail [email protected]
source ~/.bashrc
cd ~
acme.shのバージョンを確認してください:
acme.sh --version
# v2.8.0
RSAを取得する およびECC/ ECCSA ドメイン/ホスト名の証明書:
# RSA 2048
acme.sh --issue --standalone -d example.com --keylength 2048
# ECDSA
acme.sh --issue --standalone -d example.com --keylength ec-256
テスト用の偽の証明書が必要な場合は、-staging
を追加できます 上記のコマンドにフラグを立てます。
上記のコマンドを実行した後、証明書 およびキー になります:
- RSAの場合 :
/home/username/example.com
ディレクトリ。 - ECC / ECCSAの場合 :
/home/username/example.com_ecc
ディレクトリ。
発行された証明書を一覧表示するには、次のコマンドを実行できます:
acme.sh --list
証明書を保存するディレクトリを作成します。 / etc /letsencrypt
を使用します ディレクトリ。
mkdir -p /etc/letsecnrypt/example.com
sudo mkdir -p /etc/letsencrypt/example.com_ecc
証明書を/etc/letsencryptディレクトリにインストール/コピーします。
# 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"
すべての証明書は60日ごとに自動的に更新されます。
証明書を取得したら、rootユーザーを終了し、通常のsudoユーザーに戻ります。
exit
ステップ4-NGINXをインストールし、Vanillaフォーラム用にNGINXを構成します
バニラフォーラムは、多くの一般的なウェブサーバーソフトウェアで正常に機能します。このチュートリアルでは、NGINXを選択しました。 NGINXよりもApacheWebサーバーを使用する場合は、https://docs.vanillaforums.com/developer/backend/server-apache/にアクセスして詳細を確認してください。
FedoraリポジトリからNGINXをダウンロードしてインストールします:
sudo dnf install -y nginx
NGINXのバージョンを確認してください:
nginx -v
# nginx version: nginx/1.14.2
NGINXサービスを開始して有効にします:
sudo systemctl start nginx.service
sudo systemctl enable nginx.service
次のコマンドを実行して、Vanilla用にNGINXを構成します:
sudo vim /etc/nginx/conf.d/vanilla.conf
そして、ファイルに次の構成を入力します。
server {
listen 80;
listen 443 ssl http2;
server_name example.com;
root /var/www/vanilla;
index index.php;
# RSA
ssl_certificate /etc/letsencrypt/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/example.com/private.key;
# ECC/ECDSA
ssl_certificate /etc/letsencrypt/example.com_ecc/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/example.com_ecc/private.key;
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 /uploads/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(/|$) {
include default.d/php.conf;
fastcgi_param SCRIPT_NAME /index.php;
fastcgi_param SCRIPT_FILENAME $realpath_root/index.php;
fastcgi_param X_REWRITE 1;
fastcgi_pass unix:/run/php-fpm/www.sock;
}
location ~* \.php(/|$) {
rewrite ^ /index.php$uri last;
}
location / {
try_files $uri $uri/ @vanilla;
}
location @vanilla {
rewrite ^ /index.php$uri last;
}
}
注 : Vanillaの完全で本番環境に対応したNginx構成については、https://docs.vanillaforums.com/developer/backend/server-nginx/にアクセスしてください。
構文エラーがないかNGINX構成を確認してください:
sudo nginx -t
NGINXサービスをリロードします:
sudo systemctl reload nginx.service
Vanilla Forumが存在するドキュメントルートディレクトリを作成します:
sudo mkdir -p /var/www/vanilla
/ var / www / vanilla
の所有権を変更します { journal_user}
へのディレクトリ :コード>
sudo chown -R {your_user}:{your_user} /var/www/vanilla
注 : { journal_user}
を置き換えます 最初に作成したroot以外のユーザーのユーザー名を使用します。
ドキュメントのルートディレクトリに移動します:
cd /var/www/vanilla
バニラフォーラムのzipアーカイブをダウンロードします:
wget https://open.vanillaforums.com/get/vanilla-core-2.8.1.zip
Vanilla zipアーカイブを抽出して削除します:
unzip vanilla-core-2.8.1.zip
rm vanilla-core-2.8.1.zip
mv vanilla-2.8.1/* . && mv vanilla-2.8.1/.* .
適切な所有権を提供します:
sudo chown -R nginx:nginx /var/www/vanilla
sudo vim /etc/php-fpm.d/www.conf
を実行します ユーザーとグループをnginx
に設定します 。最初は、 apache:
に設定されます
sudo vim /etc/php-fpm.d/www.conf
# user = nginx
# group = nginx
WebブラウザでVanillaをアップロードしたフォルダに移動し、画面の指示に従います。
Webブラウザーでサイトを開いた後、次のページにリダイレクトされます。
必要な情報を入力して、[続行]→[]をクリックします ボタンをクリックして、インストールとセットアップを完了します。その後、VanillaForumの管理インターフェースが表示されます。
- https://open.vanillaforums.com/
- https://github.com/vanilla/vanilla