PHP 8.1.0 Alpha 1 available for testing

Configuration à l'exécution

Le comportement de ces fonctions est affecté par la configuration dans le fichier php.ini.

Options de configuration d'OPcache
Nom Défaut Modifiable Historique
opcache.enable "1" PHP_INI_ALL  
opcache.enable_cli "0" PHP_INI_SYSTEM Entre PHP 7.1.2 et 7.1.6 inclusivement, la valeur par défaut était de "1"
opcache.memory_consumption "128" PHP_INI_SYSTEM  
opcache.interned_strings_buffer "8" PHP_INI_SYSTEM  
opcache.max_accelerated_files "10000" PHP_INI_SYSTEM  
opcache.max_wasted_percentage "5" PHP_INI_SYSTEM  
opcache.use_cwd "1" PHP_INI_SYSTEM  
opcache.validate_timestamps "1" PHP_INI_ALL  
opcache.revalidate_freq "2" PHP_INI_ALL  
opcache.revalidate_path "0" PHP_INI_ALL  
opcache.save_comments "1" PHP_INI_SYSTEM  
opcache.fast_shutdown "0" PHP_INI_SYSTEM Supprimé en PHP 7.2.0.
opcache.enable_file_override "0" PHP_INI_SYSTEM  
opcache.optimization_level "0x7FFEBFFF" PHP_INI_SYSTEM Modifié depuis 0x7FFFBFFF en PHP 7.3.0
opcache.inherited_hack "1" PHP_INI_SYSTEM Supprimé en PHP 7.3.0
opcache.dups_fix "0" PHP_INI_ALL  
opcache.blacklist_filename "" PHP_INI_SYSTEM  
opcache.max_file_size "0" PHP_INI_SYSTEM  
opcache.consistency_checks "0" PHP_INI_ALL  
opcache.force_restart_timeout "180" PHP_INI_SYSTEM  
opcache.error_log "" PHP_INI_SYSTEM  
opcache.log_verbosity_level "1" PHP_INI_SYSTEM  
opcache.preferred_memory_model "" PHP_INI_SYSTEM  
opcache.protect_memory "0" PHP_INI_SYSTEM  
opcache.mmap_base null PHP_INI_SYSTEM  
opcache.restrict_api "" PHP_INI_SYSTEM  
opcache.file_update_protection "2" PHP_INI_ALL  
opcache.huge_code_pages "0" PHP_INI_SYSTEM  
opcache.lockfile_path "/tmp" PHP_INI_SYSTEM  
opcache.opt_debug_level "0" PHP_INI_SYSTEM Disponible à partir de PHP 7.1.0
opcache.file_cache NULL PHP_INI_SYSTEM  
opcache.file_cache_only "0" PHP_INI_SYSTEM  
opcache.file_cache_consistency_checks "1" PHP_INI_SYSTEM  
opcache.file_cache_fallback "1" PHP_INI_SYSTEM Windows uniquement.
opcache.validate_permission "0" PHP_INI_SYSTEM Disponible à partir de PHP 7.0.14
opcache.validate_root "0" PHP_INI_SYSTEM Disponible à partir de PHP 7.0.14
opcache.preload "" PHP_INI_SYSTEM Disponible à partir de PHP 7.4.0
opcache.preload_user "" PHP_INI_SYSTEM Disponible à partir de PHP 7.4.0
opcache.cache_id "" PHP_INI_SYSTEM Windows uniquement. Disponible à partir de PHP 7.4.0
opcache.jit "tracing" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_buffer_size "0" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_debug "0" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_bisect_limit "0" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_prof_threshold "0.005" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_max_root_traces "1024" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_max_side_traces "128" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_max_exit_counters "8192" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_hot_loop "64" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_hot_func "127" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_hot_return "8" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_hot_side_exit "8" PHP_INI_SYSTEM Disponible à partir de PHP 8.0.0
opcache.jit_blacklist_root_trace "16" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_blacklist_side_trace "8" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_max_loop_unrolls "8" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_max_recursive_calls "2" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_max_recursive_returns "2" PHP_INI_ALL Disponible à partir de PHP 8.0.0
opcache.jit_max_polymorphic_calls "2" PHP_INI_ALL Disponible à partir de PHP 8.0.0
Pour plus de détails sur les modes PHP_INI_*, reportez-vous à Où une directive de configuration peut être modifiée.

Voici un éclaircissement sur l'utilisation des directives de configuration.

opcache.enable bool

Active le cache d'opcode. Lorsqu'il est désactivé, le code n'est ni optimisé, ni mis en cache. Le paramétrage de opcache.enable ne peut être activé pendant l'exécution via la fonction ini_set(), il ne peut être que désactivé. Tenter de l'activer dans un script va générer une alerte.

opcache.enable_cli bool

Active le cache d'opcode pour la version CLI de PHP.

opcache.memory_consumption int

La taille de la mémoire partagée utilisée par OPcache, en megabytes. La valeur minimale permissible est "8", qui est forcé si une valeur plus petite est définie.

opcache.interned_strings_buffer int

La quantité de mémoire utilisée pour stocker des chaînes internes, en megabytes. Cette directive de configuration est ignorée dans PHP < 5.3.0.

opcache.max_accelerated_files int

Le nombre maximal de clés (et donc, de scripts) dans la table de hachage d'OPcache. La valeur actuellement utilisée sera le premier nombre du jeux des nombres premiers { 223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987, 262237, 524521, 1048793 } qui est plus grand ou égal que la valeur configurée. La valeur minimale est 200. La valeur maximale est 100000 dans PHP < 5.5.6, et 1000000 dans les versions ultérieur. Les valeurs hors de cette intervalle sont fixées à l'intervalle autorisé.

opcache.max_wasted_percentage int

Le pourcentage maximum de mémoire gaspillée autorisée avant qu'un redémarrage ne soit programmé, s'il n'y a pas assez de mémoire disponible. La valeur maximale permissible est "50", qui est forcé si une valeur plus large est définie.

opcache.use_cwd bool

Si activé, OPcache ajoute le dossier de travail courant à la clé du script, éliminant ainsi les collisions possibles entre les fichiers dont le nom de base est identique. Le fait de désactiver cette fonctionnalité améliore les performances, mais peut casser les applications existantes.

opcache.validate_timestamps bool

Si activé, OPcache va vérifier les mises à jour des scripts toutes les opcache.revalidate_freq secondes. Lorsque cette directive est désactivée, vous devez réinitialiser OPcache manuellement via la fonction opcache_reset(), la fonction opcache_invalidate() ou en redémarrant le serveur Web pour que les modifications du système de fichiers ne prennent effet.

opcache.revalidate_freq int

La fréquence de vérification du timestamps du script afin de détecter les possibles mises à jour, en secondes. La valeur 0 fera qu'OPcache vérifiera les mises à jour à chaque requête.

Cette directive de configuration est ignorée si opcache.validate_timestamps est désactivé.

opcache.revalidate_path bool

Si désactivé, les fichiers en cache existant utilisant le même include_path seront réutilisés. Aussi, si un fichier avec le même nom est quelque part ailleurs dans le include_path, il ne sera pas trouvé.

opcache.save_comments bool

Si désactivé, tous les commentaires de documentation seront supprimés du cache opcode afin de réduire la taille du code optimisé. La désactivation de cette directive peut casser des applications et des frameworks qui s'appuient sur l'analyse des commentaires pour les annotations, comme Doctrine, Zend Framework 2 et PHPUnit.

opcache.fast_shutdown bool

Si activé, une séquence d'arrêt rapide sera utilisé, qui ne libère pas chaque bloc alloué, mais s'appuie sur le gestionnaire de mémoire Zend Engine pour désallouer le jeux entier des variables de requêtes, en masse.

Cette directive a été supprimé dans PHP 7.2.0. Une variante de la séquence d'arrêt rapide a été intégré dans PHP et sera automatiquement utilisé si possible.

opcache.enable_file_override bool

Lorsqu'activé, le cache opcode sera vérifié pour savoir si un fichier a déjà été mise en cache lorsque les fonctions file_exists(), is_file() et is_readable() sont appelées. Ceci peut accroître les performances des applications qui vérifient l'existence et la lisibilité des scripts PHP, mais risque de retourner des données périmées si opcache.validate_timestamps est désactivé.

opcache.optimization_level int

Un masque de bits qui contrôle l'optimisation passée à exécuter.

opcache.inherited_hack bool

Cette directive de configuration est ignorée.

opcache.dups_fix bool

Ce hack ne doit être activé que comme solution de contournement des erreurs "Cannot redeclare class".

opcache.blacklist_filename string

L'endroit de stockage du fichier gérant la liste noire OPcache. Un fichier de liste noire est un fichier texte contenant des noms de fichiers qui ne doivent pas être accélérés ; un par ligne. Les jokers sont autorisés, et les préfixes peuvent également être fournis. Les lignes commençant par un point-virgule sont vues comme des commentaires et seront donc ignorées.

Un fichier de liste noire simple ressemble à ceci :

; Correspond à un fichier spécifique.
/var/www/broken.php
; Un préfixe qui correspond à tous les fichiers qui commencent par x.
/var/www/x
; Une correspondance avec un joker.
/var/www/*-broken.php
opcache.max_file_size int

La taille maximale du fichier pouvant être mis en cache, en octets. Si vaut 0, tous les fichiers pourront être mise en cache.

opcache.consistency_checks int

Si vaut différent de zéro, OPcache va vérifier la somme de contrôle du cache toutes les N requêtes, où N est la valeur de cette directive de configuration. Ceci ne doit être activé que lors du débogage, sachant qu'il impacte fortement les performances.

opcache.force_restart_timeout int

La durée à attendre pour le début d'un redémarrage programmé, si le cache n'est pas activé, en seconde. Si ce délai d'attente est atteint, alors OPcache imagine que quelque chose se passe mal, et va tuer les processus gérant les verrous sur le cache pour permettre un redémarrage.

Si opcache.log_verbosity_level vaut 2 ou plus, un avertissement sera enregistrée dans le journal d'événements des erreurs lorsque ce comportement survient.

Cette directive n'est pas supporté sur Windows.

opcache.error_log string

Le log d'erreurs pour les erreurs OPcache. Une chaîne vide sera vu comme stderr, et les erreurs seront envoyées vers la sortie d'erreurs standard (qui sera le log des erreurs du serveur Web dans la plupart des cas).

opcache.log_verbosity_level int

Le niveau de verbosité des logs. Par défaut, seules les erreurs fatales niveau 0) et les erreurs (niveau 1) seront enregistrées. Les autres niveaux disponibles sont les alertes (niveau 2), les messages d'information (niveau 3), et les messages de débogage (niveau 4).

opcache.preferred_memory_model string

Le modèle de mémoire préféré pour OPcache, à utiliser. Si laissé vide, OPcache va choisir le modèle le plus approprié, ce qui est la meilleure façon de faire dans la plupart des cas.

Les valeurs possibles sont mmap, shm, posix et win32.

opcache.protect_memory bool

Protège la mémoire partagée des écritures non-approuvées pendant l'exécution des scripts. Ceci est utile uniquement pour du débogage interne.

opcache.mmap_base string

La base utilisée pour les segments de mémoire partagée sous Windows. Tous les processus PHP doivent lier la mémoire partagée dans le même espace d'adresse. L'utilisation de cette directive permet de corriger les erreurs "Unable to reattach to base address".

opcache.restrict_api string

Autorise l'appel aux fonctions de l'API d'OPcache uniquement depuis des scripts PHP dont le chemin commence par une chaîne spécifique. La valeur par défaut, "", signifie "aucune restriction".

opcache.file_update_protection string

Empêche la mise en cache des fichiers datant moins que ce nombre de secondes. Ceci protège de la mise en cache des fichiers incomplètement mis à jour. Si toutes les mises à jour de fichiers sur votre site sont atomiques, vous pouvez augmenter les performances en le définissant à "0".

opcache.huge_code_pages bool

Active ou désactive la copie de code PHP (segment de texte) dans des HUGE PAGES. Ceci devrait améliorer les performances, mais nécessite une configuration approprié du système d'exploitation. Disponible sur Linux à partir de PHP 7.0.0, et sur FreeBSD à partir de PHP 7.4.0.

opcache.lockfile_path string

Chemin absolue utilisé pour enregistrer les lockfiles partagés (pour *nix uniquement)

opcache.opt_debug_level string

Produit un vidage opcode pour déboguer les différents étapes d'optimisation. 0x10000 affichera les opcodes tel que le compilateur les produit avant qu'aucune optimisation se produisent alors que 0x20000 affichera les codes optimisés.

opcache.file_cache string

Active et définie le répertoire de cache de second niveau. Ceci devrait améliorer les performances quand la mémoire SHM est pleine, au redémarrage du serveur ou réinitialisation de SMH. La valeur par défaut "" désactive la mise en cache basée sur les fichiers.

opcache.file_cache_only bool

Active ou désactive la mise en cache de l'opcode dans la mémoire partagée.

opcache.file_cache_consistency_checks bool

Active ou désactive la validation de la somme de contrôle lorsque le script est chargé à partir du cache de fichiers.

opcache.file_cache_fallback bool

Insinue opcache.file_cache_only=1 pour un certain processus qui a échoué de se rattacher à la mémoire partagée (pour Windows uniquement). Le cache de fichiers activé explicitement est requis.

Attention

Désactiver cette option de configuration peut empêcher les processus de démarrer, Disabling this configuration option may prevent processes to start, et est donc découragé.

opcache.validate_permission bool

Valide les permissions des fichiers mises en cache par rapport à l'utilisateur actuel.

opcache.validate_root bool

Empêche la collision de noms dans les environnements `chroot`ées. Ceci devrait être activé dans tous les environnements `chroot`ées pour empêcher l'accès aux fichiers en-dehors du chroot.

opcache.preload string

Spécifie un script PHP qui sera compilé et exécuté lors du démarrage du serveur, et qui peut précharger d'autres fichiers, soit grâce à include ou en utilisant la fonction opcache_compile_file(). Toutes les entités (par exemple fonctions et classes) définies dans ces fichiers seront disponibles aux requêtes prêt à l'emploi, jusqu'à ce que le serveur soit éteint.

Note:

Le préchargement n'est pas supporté sur Windows.

opcache.preload_user string

Le code de préchargement en tant que racine n'est pas autorisé pour des raisons de sécurité. Cette directive facilite la gestion du préchargement en tant qu'utilisateur.

opcache.cache_id string

Sur Windows, tous les processus exécutant le même PHP SAPI sous le même compte utilisateur ayant le même ID de cache partage une instance unique de OPcache. La valeur de l'ID de cache peut être choisi librement.

Astuce

Pour IIS, des pools d'applications différentes peuvent avoir leur propre instance OPcache en utilisant la variable d'environnement APP_POOL_ID comme opcache.cache_id. For IIS, different application pools can have their own OPcache instance by using the environment variable APP_POOL_ID as opcache.cache_id.

opcache.jit string|int

Pour un usage typique, cette option accepte une des quatre valeur string suivante :

  • disable: Désactivé complètement, ne peut pas être activé lors du runtime.
  • off: Désactivé, mais peut être activé lors du runtime.
  • tracing/on: Utilise le tracing JIT. Activé par défaut et recommandé pour la plupart des utilisateurs.
  • function: Utilise le function JIT.

Pour un usage avancé, cette option accepte un entier à 4 chiffre CRTO, où les chiffres signifient :

C (Drapeaux d'optimisation spécifique au CPU)
  • 0: Désactive les optimisations spécifique de CPU.
  • 1: Active l'usage d'AVX, si le CPU le supporte.
R (allocation de registre)
  • 0: N'accomplie aucune allocation de registre
  • 1: Accomplie des allocations de registre au niveau d'un block.
  • 2: Accomplie des allocations de registre globale.
T (trigger/déclencheur)
  • 0: Compile toutes les fonctions lors du chargement du script.
  • 1: Compile les fonctions lors de leur première exécution.
  • 2: Profile les fonctions lors de la première requête et compile les fonctions les plus chaudes juste après.
  • 3: Profile à la volée et compile les fonctions chaudes.
  • 4: Actuellement inutilisé.
  • 5: Utilise le tracing JIT. Profile à la volée et compile les traces pour les segments de code chaud.
O (niveau d'optimisation)
  • 0: Pas de JIT.
  • 1: JIT minimal (appelle les handlers standard de la VM).
  • 2: Inline les handlers de la VM.
  • 3: Utilise l'inférence de type.
  • 4: Utilise un graphe d'appel.
  • 5: Optimise le script entier.
Le mode "tracing" corresponds à CRTO = 1254, le mode "function" corresponds à CRTO = 1205.

opcache.jit_buffer_size int

La quantité de mémoire partagé réservé pour du code compilé JIT. Une valeur de zéro désactive le JIT.

Lorsqu'un entier est utilisé, sa valeur est mesurée en octets. Vous pouvez également utiliser la notation sténographique comme décrit dans cette entrée de la FAQ..
opcache.jit_debug int

Un masque de bit spécifiant quel sortie de débug de JIT à activer Pour les valeurs possible, consultez zend_jit.h.

opcache.jit_bisect_limit int

Option de débogage qui désactive la compilation JIT après la compilation d'un certain nombre de fonctions. Ceci peut être utile pour bisect la source d'une mauvaise compilation JIT.

opcache.jit_prof_threshold float

Lors de l'utilisation du mode de déclencheur "profile les fonctions lors de la première requête", cette limite détermine si une fonction est considéré chaude. Le nombre d'appels à la fonction divisé par le nombre d'appel à toutes les fonctions doit être supérieur à cette limite. Par exemple, un limite de 0.005 signifie qu'une fonction qui correspond à plus de 0.5% de tout les appels sera compilé JIT.

opcache.jit_max_root_traces int

Nombre maximal de traces racines (root traces).

opcache.jit_max_side_traces int

Nombre maximal de traces adjacent (side trace) une trace racine peut avoir.

opcache.jit_max_exit_counters int

Nombre maximal de compteur de sortie de trace adjacent. Ceci limite le nombre total de traces adjacentes qu'il peut y avoir, à travers toutes les traces racines.

opcache.jit_hot_loop int

Après combien d'itération une boucle est considéré chaude.

opcache.jit_hot_func int

Après combien d'appel une fonction est considéré chaude.

opcache.jit_hot_return int

Après combien de retours un retour est considéré chaud.

opcache.jit_hot_side_exit int

Après combien de sortie, une sortie adjacent est considéré chaude.

opcache.jit_blacklist_root_trace int

Nombre maximal de fois la compilation d'une trace racine est tenté avant qu'elle soit exclut.

opcache.jit_blacklist_side_trace int

Nombre maximal de fois la compilation d'une trace adjacent est tenté avant qu'elle soit exclut.

opcache.jit_max_loop_unrolls int

Nombre maximal de tentative à dérouler une boucle dans une trace adjacent, tentant d'atteindre la trace racine et de fermer la boucle extérieur.

opcache.jit_max_recursive_calls int

Nombre maximal d'appel récursif déroulé dans une boucle.

opcache.jit_max_recursive_returns int

Nombre maximal de retour récursif déroulé dans une boucle.

opcache.jit_max_polymorphic_calls int

Nombre maximal de tentative à inline un appel polymorphic (dynamique ou méthode). Appels au-dessus de cette limité sont traité comme megamorphic et ne sont pas inlined.

add a note add a note

User Contributed Notes 6 notes

up
7
wessos at example dot org
2 years ago
The optimization levels as of php 7.3 are the following:

#define ZEND_OPTIMIZER_PASS_1        (1<<0)   /* CSE, STRING construction     */
#define ZEND_OPTIMIZER_PASS_2        (1<<1)   /* Constant conversion and jumps */
#define ZEND_OPTIMIZER_PASS_3        (1<<2)   /* ++, +=, series of jumps      */
#define ZEND_OPTIMIZER_PASS_4        (1<<3)   /* INIT_FCALL_BY_NAME -> DO_FCALL */
#define ZEND_OPTIMIZER_PASS_5        (1<<4)   /* CFG based optimization       */
#define ZEND_OPTIMIZER_PASS_6        (1<<5)   /* DFA based optimization       */
#define ZEND_OPTIMIZER_PASS_7        (1<<6)   /* CALL GRAPH optimization      */
#define ZEND_OPTIMIZER_PASS_8        (1<<7)   /* SCCP (constant propagation)  */
#define ZEND_OPTIMIZER_PASS_9        (1<<8)   /* TMP VAR usage                */
#define ZEND_OPTIMIZER_PASS_10        (1<<9)   /* NOP removal                 */
#define ZEND_OPTIMIZER_PASS_11        (1<<10)  /* Merge equal constants       */
#define ZEND_OPTIMIZER_PASS_12        (1<<11)  /* Adjust used stack           */
#define ZEND_OPTIMIZER_PASS_13        (1<<12)  /* Remove unused variables     */
#define ZEND_OPTIMIZER_PASS_14        (1<<13)  /* DCE (dead code elimination) */
#define ZEND_OPTIMIZER_PASS_15        (1<<14)  /* (unsafe) Collect constants */
#define ZEND_OPTIMIZER_PASS_16        (1<<15)  /* Inline functions */

Source: https://lxr.room11.org/xref/php-src%40master/ext/opcache/Optimizer/zend_optimizer.h
up
9
damien at overeem dot org
4 years ago
When using PHP on a windows platform and enabling opcache, you might run into occasional 500 errors. These will appear to show up entirely random.

When this happens, your windows Event log (Windows Logs/Application) will show (probably multiple)  entries from Zend OPcache with Event ID 487. Further information will state the following error message: "Base address marks unusable memory region".

This issue can be resolved by adding the following to your php.ini:

    opcache.mmap_base = 0x20000000

Unfortunately I do not know the significance of the value "0x20000000". I can only tell you that this value works to solve the problem (Tried and tested)
up
4
tizian dot schmidlin at gmail dot com
2 years ago
It should be noted that according to the original RFC (https://wiki.php.net/rfc/preload) `opcache.preload` caches preloaded files *forever* for all instances of the underlying PHP process.

That means, that hosting multiple websites on the same server might result in some unexpected behaviour.

Concrete example:
- you have a Symfony 3.2 App (which might be an endpoint of some type) and a Symfony 3.4 App (which might be your main application)
- both apps have a main Class called App that is in the same namespace (as it is usual, since the class name is unique to each project)
- depending on which app is loaded first, one or the other will work, since `opcache.preload` has no file based distinction of what class is used where and simply provides them to the user space

This is avoidable by simply not preloading user space classes or, if you work with FPM, by defining a pool for each app.

In order to optimize memory consumption, you might also use a common FPM Pool for all Symfony 3.4 Apps and preload the entire framework in there and simply not preload user space classes (which might be cached by opcache anyway but is slower, since it will be checked if the file has changed on every request).
up
2
carneiro at isharelife dot com dot br
1 year ago
If you try to allocate more memory that is available using opcache.memory_consumption PHP stops working without any logs to help on debugging. This issue took me 4 hours to solve when creating a staging server with same configrations and less memory that was available on production server.
up
3
bdurand at ensemblegroup dot net
4 years ago
It would appear as though the [opcache.enable] setting is indeed NOT PHP_INI_ALL.
For changing it within user.ini yields no effect when disabled at global level. user.ini is ignored for that setting.
up
-14
BR
5 years ago
opcache.max_wasted_percentage must have a value between 1 and 50. Otherwise it will automatically set the variable 5 %.
To Top