blackbird / module-eav-optimize
Improve EAV attribute option performance
Installs: 230
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 2
Open Issues: 1
Type:magento2-module
Requires
- magento/framework: *
- magento/module-eav: *
README
Description
The EavOptimize plugin provides a solution to optimize the performance of fetching attribute options in Magento 2. It introduces memoization and caching for EAV (Entity-Attribute-Value) attribute option values, which can improve store performance by reducing redundant database calls.
Additionally, this module forces the default value of cache_user_defined_attributes
system configuration to 1
, ensuring that custom attributes are cached by default for better efficiency.
You can still disable this config in adminhtml.
See existing Magento issue: magento/magento2#36174 See in progress official PR: magento/magento2#39476
Features
- Memoization: Stores attribute option values in memory for faster repeated access during the same request lifecycle.
- Caching: Adds caching for custom attribute values fetched through
getAttributeText()
calls for improved overall performance. - Configuration Options in Admin Panel: Allows enabling or disabling caching through a Magento System Configuration field.
- Default Caching Behavior: Automatically activates caching for custom attributes by setting
cache_user_defined_attributes
to1
by default in the configuration.
Configuration
To manage the caching behavior, navigate to the Admin Panel:
- Go to
Stores > Configuration > Advanced > Developer
. - Locate the Caching section.
- Check the
Cache Attribute Options Values
setting:- Yes (default): Enables caching for attribute option values retrieved using
getAttributeText()
. - No: Disables caching.
- Yes (default): Enables caching for attribute option values retrieved using
Installation
-
Install the module using composer:
composer require blackbird/module-eav-optimize
-
Run the following commands to register and enable the module:
bin/magento module:enable Blackbird_EavOptimize bin/magento setup:upgrade bin/magento cache:flush
Technical Details
Why Use EavOptimize?
Fetching EAV attribute options using getAttributeText()
in Magento can result in multiple redundant queries, especially in cases where multiple calls retrieve the same data. The EavOptimize
plugin avoids such performance bottlenecks by leveraging memoization to reuse data within a single request and caching to persist retrieved attribute options across requests.
Changes Introduced
- The plugin overrides or interacts with default Magento EAV functionality to add memoization for EAV attribute option values at runtime in the class
Magento\Eav\Model\Entity\Attribute\Source\Table
. - Adjustments are made to cache attribute options by default through
config.xml
:<default> <dev> <caching> <cache_user_defined_attributes>1</cache_user_defined_attributes> <cache_option_values>1</cache_option_values> </caching> </dev> </default>
- A system configuration option has been added (
system.xml
) to allow admin users to control caching behavior (Cache Attribute Options Values
).
Performance Benefits
- Reduces the number of database queries during attribute option lookups.
- Improves overall page load times, especially for pages that frequently query for attribute text (e.g., product pages, category pages).
- Ensures smoother performance under heavy load.
Compatibility
This module is compatible with:
- Magento 2 version 2.3.x and above.
- PHP version used should align with Magento's compatibility.
Usage Example
Without EavOptimize:
When fetching an attribute's option text multiple times (e.g., by calling getAttributeText()
in a loop), Magento may execute redundant database calls to retrieve the same data repeatedly.
With EavOptimize:
The plugin stores these values in memory through memoization during runtime. For subsequent calls, the data is fetched directly from memory or cache instead of querying the database.
Example:
$product = $productRepository->getById(1); echo $product->getAttributeText('color'); // First call - fetched from DB or cache echo $product->getAttributeText('color'); // Second call - fetched from memoized storage
Enjoy improved performance while managing your EAV attributes with EavOptimize! 🚀