WordPress est de loin la plate-forme de blogging et de CMS open source la plus populaire qui alimente plus d'un quart des sites Web du monde. Il est basé sur PHP et MySQL et contient une tonne de fonctionnalités qui peuvent être étendues avec des plugins et des thèmes gratuits et premium. WordPress est le moyen le plus simple de créer votre boutique en ligne, votre site Web ou votre blog.
Dans ce tutoriel, nous allons vous montrer comment installer WordPress sur une machine Ubuntu 18.04. Il s'agit d'un processus assez simple qui prend moins de dix minutes.
Nous utiliserons une pile LEMP avec Nginx comme serveur Web, un certificat SSL, le dernier PHP 7.2 et MySQL/MariaDB comme serveur de base de données.
Prérequis #
Assurez-vous que vous avez satisfait aux prérequis suivants avant de poursuivre ce didacticiel :
- Vous avez un nom de domaine pointant vers l'IP publique de votre serveur. Nous utiliserons
example.com
. - Vous êtes connecté en tant qu'utilisateur avec des privilèges sudo.
- Vous avez installé Nginx en suivant ces instructions.
- Un certificat SSL installé pour votre domaine. Vous pouvez installer un certificat SSL Let's Encrypt gratuit en suivant ces instructions.
Mettez à jour l'index des packages et les packages système vers les dernières versions :
sudo apt update
sudo apt upgrade
Création de la base de données MySQL #
WordPress utilise la base de données MySQL pour stocker toutes ses données. Notre première étape consiste à créer une base de données MySQL, un compte utilisateur MySQL et à accorder l'accès à la base de données.
Si MySQL ou MariaDB n'est pas déjà installé sur votre serveur Ubuntu, vous pouvez l'installer en suivant l'une des instructions ci-dessous :
- Installer MySQL sur Ubuntu 18.04
- Installer MariaDB sur Ubuntu 18.04
Connectez-vous au shell MySQL en tapant la commande suivante et entrez le mot de passe lorsque vous y êtes invité :
mysql -u root -p
Depuis le shell MySQL, exécutez les instructions SQL suivantes pour créer une base de données nommée wordpress
, utilisateur nommé wordpressuser
et d'accorder toutes les autorisations nécessaires à l'utilisateur :
CREATE DATABASE wordpress CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
GRANT ALL ON wordpress.* TO 'wordpressuser'@'localhost' IDENTIFIED BY 'change-with-strong-password';
FLUSH PRIVILEGES;
EXIT;
Après avoir exécuté les commandes ci-dessus, vous aurez une nouvelle base de données MySQL et un nouveau compte utilisateur, qui seront utilisés par votre instance WordPress.
Installation de PHP #
PHP 7.2, qui est la version PHP par défaut dans Ubuntu 18.04, est entièrement pris en charge et recommandé pour WordPress.
Pour installer PHP et toutes les extensions PHP requises, exécutez la commande suivante :
sudo apt install php7.2-cli php7.2-fpm php7.2-mysql php7.2-json php7.2-opcache php7.2-mbstring php7.2-xml php7.2-gd php7.2-curl
Nous avons installé PHP-FPM car nous allons utiliser Nginx comme serveur Web.
Le service PHP-FPM démarrera automatiquement une fois le processus d'installation terminé.
Téléchargement Wordpress #
Avant de télécharger l'archive Wordpress, créez d'abord un répertoire qui contiendra nos fichiers WordPress :
sudo mkdir -p /var/www/html/example.com
Notre prochaine étape consiste à télécharger la dernière version de WordPress à partir de la page de téléchargement de WordPress à l'aide de la commande wget suivante :
cd /tmp
wget https://wordpress.org/latest.tar.gz
Une fois le téléchargement terminé, extrayez l'archive WordPress et déplacez les fichiers extraits dans le répertoire racine des documents du domaine :
tar xf latest.tar.gz
sudo mv /tmp/wordpress/* /var/www/html/example.com/
Enfin, nous devons définir les autorisations correctes afin que le serveur Web puisse avoir un accès complet aux fichiers et répertoires du site.
Étant donné que Nginx et PHP s'exécutent en tant que www-data
utilisateur et groupe, pour définir la propriété correcte, exécutez la commande chown suivante :
sudo chown -R www-data: /var/www/html/example.com
Configuration de Nginx #
À présent, vous devriez déjà avoir Nginx avec certificat SSL installé sur votre système, sinon vérifiez les prérequis pour ce tutoriel.
Pour créer un nouveau bloc de serveur pour notre instance WordPress, nous utiliserons la recette Nginx du site officiel Nginx.
Ouvrez votre éditeur de texte et créez le fichier suivant :
/etc/nginx/sites-available/example.com# Redirect HTTP -> HTTPS
server {
listen 80;
server_name www.example.com example.com;
include snippets/letsencrypt.conf;
return 301 https://example.com$request_uri;
}
# Redirect WWW -> NON WWW
server {
listen 443 ssl http2;
server_name www.example.com;
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
ssl_trusted_certificate /etc/letsencrypt/live/example.com/chain.pem;
include snippets/ssl.conf;
return 301 https://example.com$request_uri;
}
server {
listen 443 ssl http2;
server_name example.com;
root /var/www/html/example.com;
index index.php;
# SSL parameters
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
ssl_trusted_certificate /etc/letsencrypt/live/example.com/chain.pem;
include snippets/ssl.conf;
include snippets/letsencrypt.conf;
# log files
access_log /var/log/nginx/example.com.access.log;
error_log /var/log/nginx/example.com.error.log;
location = /favicon.ico {
log_not_found off;
access_log off;
}
location = /robots.txt {
allow all;
log_not_found off;
access_log off;
}
location / {
try_files $uri $uri/ /index.php?$args;
}
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php7.2-fpm.sock;
}
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {
expires max;
log_not_found off;
}
}
N'oubliez pas de remplacer example.com par votre domaine Wordpress et de définir le chemin correct vers les fichiers de certificat SSL. Les extraits utilisés dans cette configuration sont créés dans ce guide.
Activez le bloc serveur en créant un lien symbolique vers le sites-enabled
répertoire :
sudo ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/
Avant de redémarrer le service Nginx faites un test pour vous assurer qu'il n'y a pas d'erreurs de syntaxe :
sudo nginx -t
S'il n'y a pas d'erreurs, la sortie devrait ressembler à ceci :
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
et vous pouvez redémarrer Nginx en tapant :
sudo systemctl restart nginx
Fin de l'installation de WordPress #
Maintenant que Wordpress est téléchargé et que la configuration du serveur est terminée, nous pouvons terminer l'installation via l'interface Web.
Ouvrez votre navigateur, tapez votre domaine et un écran similaire au suivant apparaîtra :
Sélectionnez la langue que vous souhaitez utiliser et cliquez sur Continue
bouton.
Ensuite, vous verrez la page d'informations suivante, cliquez sur Let's go!
bouton.
Sur l'écran suivant, l'assistant de configuration vous demandera d'entrer les détails de connexion à votre base de données. Entrez l'utilisateur MySQL et les détails de la base de données que vous avez créés précédemment.
Lancez l'installation en cliquant sur Run the Installation
bouton.
À l'étape suivante, vous devrez entrer un nom pour votre site WordPress et choisir un nom d'utilisateur (pour des raisons de sécurité, n'entrez pas "admin").
Le programme d'installation générera automatiquement un mot de passe fort pour vous. N'oubliez pas de sauvegarder ce mot de passe. Vous pouvez également définir vous-même le mot de passe.
Entrez votre adresse e-mail et indiquez si vous souhaitez décourager les moteurs de recherche d'indexer le site (non recommandé).
Cliquez sur Install WordPress
et une fois l'installation terminée, vous serez redirigé vers une page vous informant que WordPress a été installé. Pour accéder à votre formulaire de connexion WordPress, cliquez sur Log in
bouton.
Entrez votre nom d'utilisateur et votre mot de passe et cliquez sur Log in
bouton.
Une fois connecté, vous serez redirigé vers le tableau de bord d'administration de WordPress.
À partir de là, vous pouvez commencer à personnaliser votre installation WordPress en installant de nouveaux thèmes et plugins.