From 67ea9b6c4015d9d583fb6354ba7581a56aafeb1e Mon Sep 17 00:00:00 2001 From: Denny Septian Panggabean Date: Sat, 2 Mar 2024 10:55:38 +0700 Subject: [PATCH] docs: note preload to deployment --- .../source/installation/deployment.rst | 30 +++++++++++++++++-- .../source/installation/preloading/001.php | 20 +++++++++++++ 2 files changed, 47 insertions(+), 3 deletions(-) create mode 100644 user_guide_src/source/installation/preloading/001.php diff --git a/user_guide_src/source/installation/deployment.rst b/user_guide_src/source/installation/deployment.rst index b089b41642e0..4759b9c83fe0 100644 --- a/user_guide_src/source/installation/deployment.rst +++ b/user_guide_src/source/installation/deployment.rst @@ -59,9 +59,33 @@ See :ref:`file-locator-caching`. PHP Preloading ============== -If you want to use `Preloading `_, -we provide a -`preload script `_. +Every application consists of a large number of classes in many different locations. +The framework provides classes for core functionality. As defined by `PHP RFC `_, +Preloading is implemented as a part of the opcache on top of another (already committed) patch that introduces ``immutable`` +classes and functions. They assume that the immutable part is stored in shared memory once (for all processes) +and never copied to process memory, but the variable part is specific for each process. +The patch introduced the MAP_PTR pointer data structure, that allows pointers from SHM to process memory. + +.. note:: If you want to use `Preloading `_, + we provide a `preload script `_. + +Requirement +----------- + +Preloading for classes that are used more than once in the same server is not possible. You must isolated application to ``dedicated`` server, +even if the servers are not physical machines but virtual machines or containers. Preloading keeps the relevant definitions +in memory by reading the files specified in ``opcache.preload``. + +Configuration +------------- + +Open ``php.ini`` or ``xx-opcache.ini`` if you have split INI configuration in PHP, and recommendation set ``opcache.preload=/path/to/preload.php`` and ``opcache.preload_user=myuser``. + +.. note:: ``myuser`` is user running in your web server + +Make sure you use appstater installation, If using manual installation you must change directory in include path. + +.. literalinclude:: preloading/001.php .. _deployment-to-shared-hosting-services: diff --git a/user_guide_src/source/installation/preloading/001.php b/user_guide_src/source/installation/preloading/001.php new file mode 100644 index 000000000000..3a56fe6a9c68 --- /dev/null +++ b/user_guide_src/source/installation/preloading/001.php @@ -0,0 +1,20 @@ + '/system', // <== in this + // ... + ], + ]; + + // ... +} + +// ...