Maison >outils de développement >composer >optimisation du chargeur automatique du compositeur
Ce qui suit est une colonne de tutoriel utilisant la commande composer pour vous présenter l'optimisation du chargeur automatique du compositeur. J'espère que cela sera utile aux amis dans le besoin !
Optimisation du chargeur automatique
Normalement, le chargeur automatique de Composer s'exécute relativement rapidement. Cependant, en raison des règles de chargement automatique de PSR-4 et PSR-0, le système de fichiers doit être vérifié avant d'analyser définitivement une classe. Cela entraînera une vitesse de chargement automatique assez lente, mais dans un environnement de développement, ce sera un moyen de chargement très pratique, car lorsque vous créez une nouvelle classe, le chargeur découvrira et utilisera immédiatement la classe sans que vous soyez requis pour reconstruire la configuration du chargeur automatique.
Les problèmes causés par ce type de règle de chargement se reflètent vraiment dans l'environnement de production, vous pouvez reconstruire la configuration très facilement avant chaque déploiement, et de nouvelles configurations n'apparaîtront pas aléatoirement entre les classes de déploiement. , vous n'en avez donc pas besoin pour vérifier le système de fichiers à tout moment, vous souhaitez généralement que le chargement automatique se termine le plus rapidement possible.
Pour les raisons ci-dessus, Composer propose des stratégies d'optimisation pour les chargeurs automatiques.
Remarque : vous ne devez utiliser aucune des stratégies d'optimisation décrites dans cet article dans un environnement de développement, car cela entraînerait divers problèmes lorsque vous ajouterez ou supprimerez des classes. En fait, le gain de performances résultant de l’application de ces paramètres dans un environnement de développement est largement compensé par les problèmes qu’ils entraînent.
Niveau d'optimisation 1 : Génération de cartes de classes
Comment l'exécuter ?
Il existe plusieurs options pour activer cette fonctionnalité :
Définissez "optimize-autoloader": true dans la configuration de composer.json
Utilisez -o / - -optimize-autoloader appelle l'installation ou la mise à jour
Utilisez -o / --optimize pour appeler dump-autoload
Que fait-il ?
La génération de cartes de classes convertit essentiellement les règles PSR-4/PSR-0 en règles de cartes de classes. Cela rend tout beaucoup plus rapide, puisqu'une carte de classe connue renvoie le chemin immédiatement et Composer peut garantir que la classe est là, donc aucune vérification du système de fichiers n'est nécessaire.
Dans PHP 5.6+, les classmaps sont également mis en cache dans opcache, ce qui améliore considérablement le temps d'initialisation. Si vous vous assurez qu'opcache est activé, la carte de classe devrait se charger immédiatement et les classes se chargeront rapidement.
Compromis
Il n'y a pas de véritables compromis avec cette approche. Il doit toujours être activé en production.
Le seul problème est qu'il ne suit pas le chargement automatique (c'est-à-dire lorsqu'il ne trouve pas une classe donnée), il est donc toujours possible que les règles qui reviennent à PSR-4 entraînent des vérifications du système de fichiers. Ralentissez . Pour résoudre ce problème, il existe deux options d'optimisation secondaires que vous pouvez décider d'activer si vous effectuez de nombreuses vérifications class_exists pour des classes qui n'existent pas dans votre projet.
Niveau d'optimisation 2/A : Mappage de classes faisant autorité
Comment l'activer ?
Il existe plusieurs options pour activer cette fonctionnalité :
Définissez "classmap-authoritative": true dans la clé de configuration de composer.json
Utilisez -a / --classmap-authoritative Appel pour installer ou mettre à jour
Utilisez -a / --classmap-authoritative pour appeler dump-autoload
Que fait-il ?
L'activation de cette option active automatiquement l'optimisation de la carte de classe de niveau 1.
Cette option est simple, elle dit que si quelque chose n'est pas trouvé dans le diagramme de classes, alors il n'existe pas et l'autochargeur ne doit pas essayer de regarder le système de fichiers selon les règles PSR-4.
Compromis
Cette option permet au chargeur automatique de toujours revenir rapidement. D'un autre côté, cela signifie également que si la classe est générée au moment de l'exécution pour une raison quelconque, le chargement automatique n'est pas autorisé. Si votre projet ou l'une de ses dépendances fait cela, vous risquez de rencontrer des problèmes de « classe introuvable » en production. Faites attention à l'activer.
Remarque : Ceci ne peut pas être utilisé en conjonction avec l'optimisation de niveau 2/B. Vous devez en choisir un car ils résolvent le même problème de différentes manières.
Niveau d'optimisation 2/B : Cache APCu
Comment l'activer ?
Il existe une option pour activer cette fonctionnalité :
Définissez "apcu-autoloader": true dans la clé de configuration de composer.json
Utilisez --apcu - l'autoloader appelle l'installation ou la mise à jour
Utilisez --apcu pour appeler dump-autoload
Que fait-il ?
Cette option ajoute le cache APCu comme solution de secours pour le mappage de classes. Il ne génère pas automatiquement les classmaps, vous devez donc toujours activer manuellement l'optimisation de niveau 1 si vous le souhaitez.
Que la classe soit trouvée ou non, ce fait est toujours mis en cache dans APCu afin qu'il puisse être renvoyé rapidement lors de la prochaine requête.
Compromis
Cette option nécessite APCu, qui peut ou non fonctionner pour vous. Il utilise également la mémoire APCu pour le chargement automatique, mais son utilisation est sûre et n'empêche pas la recherche des classes, comme l'optimisation de la carte de classe faisant autorité ci-dessus.
Remarque : Ceci ne peut pas être utilisé en conjonction avec l'optimisation de niveau 2/A. Vous devez en choisir un car ils résolvent le même problème de différentes manières.
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!