Une pile FEMP, comparable à une pile LEMP sous Linux, est une collection de logiciels open source qui sont généralement installés ensemble pour permettre à un serveur FreeBSD d'héberger des sites Web dynamiques et des applications Web. FEMP est un acronyme qui signifie FreeBSD, Nginx, MySQL et PHP.
Dans ce guide, nous allons déployer des éléments d'une pile FEMP sur une instance de FreeBSD 12.0 Vultr à l'aide pkg
du gestionnaire de paquets FreeBSD.
Exigences
Avant de commencer ce guide, vous aurez besoin des éléments suivants:
- Un FreeBSD 12.0 VPS.
- Un utilisateur avec des privilèges root ou un
sudo
utilisateur pour effectuer des changements de configuration.
- Une connaissance de base du système FreeBSD et de l'interface de ligne de commande est recommandée.
Avant que tu commences
Vérifiez la version de FreeBSD.
uname -ro
# FreeBSD 12.0-RELEASE-p6
Assurez-vous que votre système FreeBSD est à jour.
freebsd-update fetch install
pkg update && pkg upgrade -y
Installez les packages nécessaires.
pkg install -y sudo vim bash curl
Créez un nouveau compte utilisateur avec votre nom d'utilisateur préféré. Nous utilisons 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!
Exécutez la visudo
commande et décommentez la %wheel ALL=(ALL) ALL
ligne pour permettre aux membres du wheel
groupe d'exécuter n'importe quelle commande.
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
Maintenant, passez à votre nouvel utilisateur avec su
:
su - johndoe
REMARQUE: remplacez johndoe
par votre nom d'utilisateur.
Configurer le fuseau horaire:
sudo tzsetup
Installation de la ligne principale Nginx
Vous pouvez installer Nginx en utilisant le gestionnaire de paquets de FreeBSD, pkg
. Un gestionnaire de paquets vous permet d'installer la plupart des logiciels sans effort à partir d'un référentiel géré par FreeBSD. Vous pouvez en savoir plus sur la façon d'utiliser pkg
ici .
Pour installer la dernière version principale de Nginx, exécutez la commande suivante:
sudo pkg install -y nginx-devel
Vérifiez la version:
nginx -v
# nginx version: nginx/1.17.1
Cette commande installera la dernière version principale, qui peut être utilisée de manière fiable sur un serveur de production. Si vous souhaitez installer la dernière version stable, utilisez simplement nginx
package au lieu de nginx-devel
.
Maintenant, activez et démarrez Nginx:
sudo sysrc nginx_enable=yes
sudo service nginx start
Pour vérifier que Nginx a démarré, vous pouvez exécuter la commande suivante:
sudo service nginx status
En conséquence, vous verrez quelque chose de semblable au suivant:
# Output
nginx is running as pid 17607.
Vous pouvez vérifier que Nginx a été installé et fonctionne sans erreur en visitant l'adresse IP publique de votre serveur dans votre navigateur Web. Accédez à your_server_IP
. Vous verrez par défaut "Bienvenue dans nginx!" page.
Installer MySQL
Encore une fois, vous pouvez utiliser pkg
pour obtenir et installer votre logiciel.
Installez MySQL en utilisant pkg
:
sudo pkg install -y mysql80-client mysql80-server
Vérifiez la version:
mysql --version
# mysql Ver 8.0.16 for FreeBSD12.0 on amd64 (Source distribution)
Maintenant, activez et démarrez MySQL:
sudo sysrc mysql_enable=yes
sudo service mysql-server start
Pour vérifier que MySQL a démarré, vous pouvez exécuter la commande suivante:
sudo service mysql-server status
Vous verrez quelque chose de similaire au suivant:
# Output
mysql is running as pid 19066.
En tant que bonne pratique, vous devez exécuter le mysql_secure_installation
script de sécurité qui supprimera certains paramètres par défaut non sécurisés et limitera légèrement l'accès à votre système de base de données.
sudo mysql_secure_installation
Il vous sera demandé de définir un mot de passe, suivi de quelques autres questions. Entrez un mot de passe fort, puis pour les autres questions, appuyez sur ENTERpour sélectionner les valeurs par défaut.
Installer PHP 7.3
Pour installer PHP 7.3
avec pkg
, exécutez cette commande:
sudo pkg install -y php73
Vérifiez la version.
php --version
# PHP 7.3.7 (cli) (built: Jul 18 2019 01:14:37) ( NTS )
# Copyright (c) 1997-2018 The PHP Group
# Zend Engine v3.3.7, Copyright (c) 1998-2018 Zend Technologies
Lien logiciel php.ini-production
vers php.ini
.
sudo ln -s /usr/local/etc/php.ini-production /usr/local/etc/php.ini
Maintenant, activez et démarrez PHP-FPM:
sudo sysrc php_fpm_enable=yes
sudo service php-fpm start
Pour vérifier que PHP-FPM a démarré, vous pouvez exécuter la commande suivante:
sudo service php-fpm status
En conséquence, vous verrez quelque chose de similaire:
# Output
php_fpm is running as pid 23005.
Installation de modules PHP (facultatif)
Pour améliorer les fonctionnalités de PHP, vous pouvez éventuellement installer des modules supplémentaires.
Pour voir actuellement compilé dans les modules PHP, vous pouvez exécuter ceci:
php -m
# [PHP Modules]
# Core
# date
# libxml
# mysqlnd
# pcre
# Reflection
# SPL
# standard
# [Zend Modules]
Pour rechercher les modules PHP disponibles, vous pouvez utiliser cette commande:
pkg search ^php73-*
Les résultats seront principalement des modules PHP 7.3 que vous pourrez installer:
# Output
# php73-7.3.7 PHP Scripting Language
# php73-Ice37-3.7.2 Modern alternative to object middleware such as CORBA/COM/DCOM/COM+
# php73-aphpbreakdown-2.2.2 Code-Analyzer for PHP for Compatibility Check-UP
# php73-aphpunit-1.8 Testing framework for unit tests
# php73-bcmath-7.3.7 The bcmath shared extension for php
# php73-brotli-0.7.0 Brotli extension for PHP
# php73-bsdconv-11.5.0 PHP wrapper for bsdconv
# php73-bz2-7.3.7 The bz2 shared extension for php
# php73-calendar-7.3.7 The calendar shared extension for php
# php73-composer-1.8.6 Dependency Manager for PHP
# php73-ctype-7.3.7 The ctype shared extension for php
# php73-curl-7.3.7 The curl shared extension for php
# . . .
Si, après des recherches, vous décidez que vous devez installer un package, vous pouvez le faire en utilisant la pkg install
commande. La plupart des applications Web PHP nécessiteront des modules supplémentaires, il est donc bon de savoir comment les rechercher.
Configurer Nginx pour utiliser le module PHP
Avant d'utiliser PHP, vous devez le configurer pour qu'il fonctionne avec Nginx.
Exécutez sudo vim /usr/local/etc/nginx/test.conf
et remplissez le fichier avec le contenu suivant:
server {
listen 80;
server_name SERVER_IP; # Replace with your IP or hostname
root /usr/local/www/nginx-dist;
index index.php index.html index.htm;
location / {
try_files $uri $uri/ =404;
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}
Enregistrez le fichier et quittez avec :+ W+Q
Maintenant, nous devons inclure test.conf
dans le nginx.conf
fichier principal . Le principal fichier de configuration Nginx vit en /usr/local/etc/nginx
tant que nginx.conf
.
Exécutez sudo vim /usr/local/etc/nginx/nginx.conf
pour ouvrir le fichier de configuration principal dans Vim et ajoutez la ligne suivante au http {}
bloc.
include test.conf;
Tester la configuration Nginx:
sudo nginx -t
Parce que vous avez apporté des modifications à la configuration dans Nginx, vous devez recharger le service pour que celles-ci soient appliquées. Sinon, Nginx fonctionnera toujours avec la configuration précédente.
sudo service nginx reload
Test du traitement PHP
Pour tester que votre système est correctement configuré pour PHP, vous pouvez créer un script PHP très basique. Vous appellerez ce script info.php
. Par défaut, le root
est défini sur /usr/local/www/nginx-dist
. Vous pouvez créer le info.php
fichier sous cet emplacement:
sudo vim /usr/local/www/nginx-dist/info.php
Ajoutez ce code à ce fichier:
<?php phpinfo(); ?>
Accédez à http://your_server_IP/ìnfo.php
et vous verrez la page suivante:
Après l'installation et la configuration, vous devez supprimer le info.php
fichier pour éviter de divulguer au public des informations sur le serveur.
sudo rm /usr/local/www/nginx-dist/info.php
Conclusion
Félicitations, vous avez réussi à installer une pile FEMP sur votre FreeBSD 12.0 VPS. Vous avez maintenant plusieurs choix pour ce que vous allez faire ensuite. Vous avez installé une plate-forme qui vous permettra d'installer la plupart des types de sites Web et de logiciels Web par-dessus.