PHPerKaigi 2025

opcache_invalidate

(PHP 5 >= 5.5.0, PHP 7, PHP 8, PECL ZendOpcache >= 7.0.0)

opcache_invalidateАннулирует закешированный скрипт

Описание

opcache_invalidate(string $filename, bool $force = false): bool

Функция аннулирует закешированный скрипт. Если параметр force не задан или задан как false, скрипт аннулируется, только если скрипт был модифицирован после помещения в кеш. Функция аннулирует только кеш в памяти, не затрагивая файловый кеш.

Список параметров

filename

Путь к скрипту.

force

Если установлено как true, кеш скрипта будет принудительно аннулирован независимо от того, требуется ли это или нет

Возвращаемые значения

Возвращает true, если кеш опкодов для filename аннулирован, либо если аннулировать нечего. В случае, если кеш опкодов отключён, возвращается false.

Смотрите также

  • opcache_compile_file() - Компилирует и кеширут PHP-скрипт без исполнения
  • opcache_reset() - Сбрасывает содержимое кеша опкодов

Добавить

Примечания пользователей 3 notes

up
15
joel at taotesting dot com
10 years ago
Beware that only existing files can be invalidated.

Instead of removing a file from opcache that you have delete, you need to call opcache_invalidate before deleting it.
up
8
dmitry dot balabka at gmail dot com
5 years ago
opcache_invalidate tries to acquire SHM lock. When the lock can not be acquired opcache_invalidate will return FALSE. During multiple concurrent opcache_invalidate calls with higher probability, the function will return FALSE.
up
9
kaare at colourbox dot com
8 years ago
Note that invalidation doesn't actually evict anything from the cache, it just forces a recompile. You can verify this by calling opcache_get_status() and seeing that the invalidated script is not actually removed from "scripts". This means it cannot be used as a more graceful alternative to opcache_reset() when the cache is full ("cache_full":true in status). The cache will eventually fill up and refuse to cache new requests if you do atomic deployment of PHP code by changing the web server's document root. It appears opcache_reset() is the only way to prevent this, but opcache_reset() can disable the cache for any amount of time while attempting to restart, causing load spikes.
To Top