Points clés: Ce tutoriel optimise Sulu, un CMS basé sur Symfony, pour des performances plus rapides dans un environnement vagabond. Il aborde la lenteur inhérente de Symfony sur les machines virtuelles avec des systèmes de fichiers partagés. Les techniques détaillées sont applicables à toute application Symfony.
Ce guide détaille la configuration de Sulu sur Vagrant, y compris le téléchargement de boîtes, la configuration du partage de dossiers, l'installation de Sulu et les améliorations cruciales des performances. Après avoir appliqué ces optimisations, https://test.app/admin
et https://test.app
devraient être considérablement plus rapides.
Configuration et optimisation de Sulu sur Vagrant
Nous utiliserons Homestead améliorés, mais les principes s'appliquent largement.
1. Configuration initiale:
git clone https://github.com/swader/homestead_improved hi_sulu cd hi_sulu; bin/folderfix.sh
Homestead.yaml
: - map: test.app to: /home/vagrant/Code/sulu/web type: symfony-sulu
(La configuration Nginx fournie est cruciale; s'adapter selon les besoins pour les environnements non homosexuels.)
2. Installation Vagrant et Sulu:
vagrant up; vagrant ssh
test.app
au fichier /etc/hosts
de votre hôte. cd Code git clone https://github.com/sulu-io/sulu-standard sulu; cd sulu git checkout master composer install
(aborder les conflits potentiels de la version PHP; mettre à niveau si nécessaire en utilisant sudo apt-get upgrade php7.0-fpm
.)
cp app/Resources/webspaces/sulu.io.xml.dist app/Resources/webspaces/sulu.io.xml cp app/Resources/pages/default.xml.dist app/Resources/pages/default.xml cp app/Resources/pages/overview.xml.dist app/Resources/pages/overview.xml cp app/Resources/snippets/default.xml.dist app/Resources/snippets/default.xml rm -rf app/cache/* rm -rf app/logs/*
app/console sulu:build dev
app/console assetic:dump
web/admin.php
et web/website.php
(changer SYMFONY_ENV
par dev
).
3. Hacks d'optimisation des performances:
app/AbstractKernel.php
S getCacheDir
et getLogDir
Méthodes à utiliser /dev/shm
pour les environnements Dev / Test. Cela déplace les journaux et le cache vers le stockage VM-local. vendor
vers un chemin VM-local (par exemple, /home/vagrant/vendors/sulu-test.app
). Cela améliore considérablement les performances en évitant l'accès au système de fichiers partagé. (Des étapes détaillées sont fournies dans l'article d'origine pour l'ajustement manuel.) Utilisez le script fourni ~/Code/bin/sulu/vendorfix.sh
ou suivez les étapes manuelles. Mettez à jour le chemin d'inclusion de votre IDE en conséquence. web/website.php
AT web/admin.php
. realpath_cache_size
et realpath_cache_ttl
dans /etc/php/7.0/fpm/php.ini
. Envisagez d'installer l'extension Twig C et de désactiver xdebug (sudo phpdismod xdebug; sudo service php7.0-fpm restart
).
4. Dépannage:
résoudre des problèmes communs comme le cache obsolète, des emplacements de classe incorrects (utiliser app/console cache:clear
, rm -rf app/cache/*
, composer update
) et la rupture du cache APC (apc_clear_cache()
). Optimiser pour le débogage au besoin.
Conclusion:
Ces optimisations améliorent considérablement les performances de Sulu sur Vagrant. Les techniques, en particulier la relocalisation du répertoire des fournisseurs et l'optimisation du log / cache, sont largement applicables à tout projet Symfony. N'oubliez pas d'adapter les chemins et les configurations à votre configuration spécifique. La section FAQ fournit un contexte supplémentaire et répond aux questions courantes sur Symfony, Sulu et les performances vagabonantes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!