Sylius est une plateforme de commerce électronique moderne pour PHP, basée sur Symfony Framework. Le code source de Sylius est hébergé sur GitHub .
Ce guide vous guidera à travers le processus d'installation de Sylius sur une nouvelle instance CentOS 7 Vultr utilisant PHP, MariaDB comme base de données et Nginx comme serveur Web.
Exigences
Pour pouvoir installer Sylius, vous aurez besoin de:
- Instance de serveur Vultr avec au moins 2048 Mo de mémoire.
- Nginx ou Apache. Dans ce guide, nous utilisons Nginx.
- PHP version 7.2 ou plus , avec quelques extensions PHP spécifique:
gd
, exif
, fileinfo
,intl
- Paramètres de configuration PHP:
memory_limit
égaux ou supérieurs à 1024M
,date.timezone
- MySQL version 5.7 ou 8.0 ou équivalent MariaDB
- Compositeur
- Node.js
- Fil
Avant que tu commences
Vérifiez la version CentOS.
cat /etc/centos-release
# CentOS Linux release 7.6.1810 (Core)
Créez un nouveau non-root
compte utilisateur avec sudo
accès et passez-y.
useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe
REMARQUE: remplacez johndoe
par votre nom d'utilisateur.
Configurez le fuseau horaire.
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Assurez-vous que votre système est à jour.
sudo yum update
Installez les packages nécessaires.
sudo yum install -y socat git wget unzip vim
Désactivez SELinux et le pare-feu.
sudo setenforce 0 ; sudo systemctl stop firewalld ; sudo systemctl disable firewalld
Installer PHP
Configurez le référentiel Webtatic YUM.
sudo rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
Installez PHP et les extensions PHP requises.
sudo yum install -y php72w-cli php72w-fpm php72w-common php72w-mysqlnd php72w-gd php72w-intl php72w-zip php72w-curl php72w-xml php72w-mbstring php72w-json
Vérifiez la version.
php --version
# PHP 7.2.21 (cli) (built: Aug 4 2019 08:42:27) ( NTS )
Démarrez et activez PHP-FPM.
sudo systemctl start php-fpm.service
sudo systemctl enable php-fpm.service
Exécutez sudo vim /etc/php.ini
et définissez memory_limit
sur 1024M
ou plus, puis configurez date.timezone
.
memory_limit = 1024M
date.timezone = Region/City
Redémarrez PHP-FPM.
sudo systemctl restart php-fpm.service
Installez MariaDB et créez une base de données
Installez le serveur de base de données MariaDB.
sudo vi /etc/yum.repos.d/MariaDB.repo
# Copy/paste this to the /etc/yum.repos.d/MariaDB.repo file
[mariadb]
name = MariaDB
baseurl = https://yum.mariadb.org/10.2/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1
sudo yum install -y MariaDB-server MariaDB-client
Vérifiez la version.
mysql --version
# mysql Ver 15.1 Distrib 10.2.16-MariaDB, for Linux (x86_64) using readline 5.1
Démarrez et activez MariaDB.
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service
Exécutez un mysql_secure installation
script pour améliorer la sécurité de MariaDB et définissez le mot de passe de l' root
utilisateur MariaDB .
sudo mysql_secure_installation
Connectez-vous au shell MariaDB en tant qu'utilisateur root.
sudo mysql -u root -p
# Enter password
Créez une base de données MariaDB et un utilisateur vides pour Sylius, et souvenez-vous des informations d'identification.
CREATE DATABASE dbname;
GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password';
FLUSH PRIVILEGES;
exit
REMARQUE: remplacez dbname
et username
par des noms appropriés pour votre configuration. Remplacez-le password
par un mot de passe fort.
Installer Nginx
Installez Nginx.
sudo yum install -y nginx
Vérifiez la version.
nginx -v
# nginx version: nginx/1.12.2
Démarrez et activez Nginx.
sudo systemctl start nginx.service
sudo systemctl enable nginx.service
Configurez Nginx pour Sylius. Exécutez sudo vim /etc/nginx/conf.d/sylius.conf
et remplissez le fichier avec la configuration suivante.
server {
listen 80;
server_name example.com;
root /var/www/sylius/public;
location / {
try_files $uri /index.php$is_args$args;
}
location ~ ^/index\.php(/|$) {
fastcgi_pass 127.0.0.1:9000;
fastcgi_split_path_info ^(.+\.php)(/.*)$;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name;
fastcgi_param DOCUMENT_ROOT $realpath_root;
internal;
}
location ~ \.php$ {
return 404;
}
client_max_body_size 6m;
}
Enregistrez le fichier et quittez avec :+ W+ Q.
Testez la configuration.
sudo nginx -t
Recharger Nginx.
sudo systemctl reload nginx.service
Installer Composer
Installez Composer globalement.
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
Vérifiez la version.
composer --version
# Composer version 1.9.0 2019-08-02 20:55:32
Installez Node.js
Installez Node.js.
sudo yum install -y gcc-c++ make
sudo -s
curl -sL https://rpm.nodesource.com/setup_10.x | bash -
exit
sudo yum install -y nodejs
Vérifiez la version.
node --version
# v10.16.3
Installer le fil
Installez le gestionnaire de packages Yarn.
curl --silent --location https://dl.yarnpkg.com/rpm/yarn.repo | sudo tee /etc/yum.repos.d/yarn.repo
sudo yum install -y yarn
Vérifiez la version.
yarn --version
# 1.17.3
Installer Sylius
Créez un répertoire racine de document.
sudo mkdir -p /var/www/sylius
Changez la propriété du /var/www/sylius
répertoire en johndoe
.
sudo chown -R johndoe:johndoe /var/www/sylius
Accédez au dossier racine du document.
cd /var/www/sylius
Lancez un nouveau projet Sylius en exécutant cette commande:
composer create-project sylius/sylius-standard .
Exécutez vim .env.local
pour entrer les détails de la base de données et pour exécuter Sylius dans un environnement de choix.
APP_ENV=prod
DATABASE_URL=mysql://username:[email protected]/dbname
REMARQUE: Remplacer username
, password
et dbname
avec les détails de votre base de données.
Une fois que tout est en place, exécutez la commande suivante pour installer Sylius:
php bin/console sylius:install -e prod
Afin de voir un frontal entièrement fonctionnel, vous devrez installer ses actifs. Sylius utilise Gulp pour créer des ressources frontales en utilisant Yarn comme gestionnaire de packages JavaScript. Une fois Yarn installé, accédez à votre répertoire de projet pour installer les dépendances.
yarn install
Créez ensuite les ressources frontales en exécutant:
yarn build
Changez la propriété du /var/www/sylius
répertoire en nginx
.
sudo chown -R nginx:nginx /var/www/sylius
Exécutez sudo vim /etc/php-fpm.d/www.conf
et définissez l'utilisateur et le groupe sur nginx
. Initialement, ils seront définis sur apache.
sudo vi /etc/php-fpm.d/www.conf
# user = nginx
# group = nginx
Créez un /var/lib/php/session/
répertoire et changez de propriétaire en nginx
.
sudo mkdir -p /var/lib/php/session && sudo chown -R nginx:nginx /var/lib/php/session
Redémarrez le service PHP-FPM.
sudo systemctl restart php-fpm.service
La plateforme de commerce électronique Sylius est installée. Par défaut, le panneau d'administration est dirigé vers /admin
.