Maison > développement back-end > tutoriel php > Cache-tricot du chapeau: Zend Opcache, Etags et mise en cache de requête

Cache-tricot du chapeau: Zend Opcache, Etags et mise en cache de requête

Lisa Kudrow
Libérer: 2025-02-17 09:29:12
original
678 Les gens l'ont consulté

Cet article explore les techniques de mise en cache PHP courantes: Zend Opcache, expire les en-têtes et la mise en cache de requête MySQL. Nous allons plonger dans d'autres stratégies dans un article ultérieur.

Caching Hat-trick: Zend Opcache, Etags and Query Caching

Avantages clés:

  • Zend Opcache, expire les en-têtes et la mise en cache de requête MySQL augmenter considérablement la vitesse d'application PHP en rationalisant le cycle de vie de la demande.
  • Pré-installer dans PHP 5.5, Zend Opcache stocke Bytecode pré-compilé dans la mémoire partagée, en évitant l'analyse et la compilation de scripts répétés.
  • expire les en-têtes (apache / nginx) levier de levier mise en cache pour les actifs statiques (images, CSS, javascript), réduisant la charge du serveur et améliorant les performances.
  • MySQL Query Caching Stores Analysed SQL Queries and leurs résultats, accélérant les requêtes identiques ultérieures et réduisant la pression de la base de données.

Comprendre le cycle de vie de la demande PHP:

Avant de plonger dans la mise en cache, passons en revue le processus de demande PHP:

  1. File Retrieval: le fichier PHP est récupéré à partir du système de fichiers du serveur.
  2. Analyse lexicale: le code est transformé en jetons pour l'analyse.
  3. Analyse: le code est vérifié pour les erreurs de syntaxe.
  4. Génération d'opcodes: les jetons sont convertis en code machine exécutable.
  5. Exécution: le code machine est exécuté.

Les techniques de mise en cache optimisent les performances en contournant les étapes 2 à 4, minimisant la consommation de ressources et améliorant les temps de réponse.

Zend Opcache:

Zend Opcache est un amplificateur de performance facilement disponible pour PHP 5.5 et plus tard. Vérifiez l'installation à l'aide de php --version (vérifiez "Zend Opcache") ou phpinfo().

Activation d'Opcache:

Modifiez votre fichier php.ini, non comment opcache.enable=1 et redémarrez votre service PHP.

Pour les versions PHP avant 5.5, installez à l'aide de PECL: pecl install zendopcache-beta.

Configuration opcache (php.ini ou /etc/php5/mods-available/opcache.ini):

Paramètres de clé:

  • opcache.memory_consumption: taille de mémoire partagée (MB). Ajuster en fonction des ressources du serveur et des besoins d'application.
  • opcache.interned_strings_buffer: mémoire pour les chaînes internées (MB).
  • opcache.max_accelerated_files: Nombre maximum de fichiers mis en cache.
  • opcache.revalidate_freq: fréquence (secondes) pour vérifier les modifications de fichiers (0 pour toujours la vérification, idéale pour le développement).
  • opcache.max_file_size: exclure les fichiers volumineux de la mise en cache (octets).
  • opcache.fast_shutdown: accélère les déconstruit (réglé sur 1).

utiliser composer require amnuts/opcache-gui et son index.php pour surveiller l'état et les performances d'Opcache.

Caching Hat-trick: Zend Opcache, Etags and Query Caching

expire les en-têtes (apache):

Le module

Apache mod_expires permet la mise en cache du navigateur des actifs statiques. L'activer en utilisant:

sudo a2enmod expires
sudo service apache2 restart
Copier après la connexion

Configurer les règles d'expiration dans votre configuration d'hôte virtuel Apache:

<IfModule mod_expires.c>
ExpiresActive On
ExpiresDefault "access plus 1 day"
ExpiresByType image/png "access plus 10 days"
ExpiresByType text/css "access plus 25 days"
</IfModule>
Copier après la connexion

(Consulter la documentation Nginx pour la configuration de Nginx.)

Caching Hat-trick: Zend Opcache, Etags and Query Caching

MySQL Query Caching:

Pour les applications lourdes en lecture, le cache de requête de MySQL peut améliorer considérablement les performances. Vérifiez votre version MySQL (mysql --version). Pour les versions 5.6.8 et plus tard, activez-la dans my.cnf (par exemple, /etc/mysql/my.cnf):

# * Query Cache Configuration
query_cache_type             = ON
query_cache_min_res_unit     = 4096
query_cache_limit            = 1M
query_cache_size             = 16M
query_cache_wlock_invalidate = OFF
Copier après la connexion

Ajuster les paramètres en fonction de la capacité et de la fréquence de mise à jour de votre serveur. Surveillez l'utilisation du cache avec SHOW STATUS LIKE "qcache%";.

Caching Hat-trick: Zend Opcache, Etags and Query Caching

Considérations de cache de requête:

  • ne fonctionne qu'avec SELECT requêtes.
  • Les requêtes doivent être identiques pour les coups de cache.
  • Seules les requêtes déterministes sont cacheables.
  • Les mises à jour du tableau invalident le cache.

Conclusion:

Cet article a introduit des stratégies de mise en cache PHP fondamentales. La partie 2 explorera des techniques avancées comme le vernis, les bibliothèques de mise en cache de vernis, Memcached et PHP.

Questions fréquemment posées (FAQ): (Celles-ci sont déjà répondues dans le texte principal, donc pas besoin de les répéter ici.)

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal