simplemage / magento2-cachewarmup
SimpleMage Cache Warmup
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:magento2-module
Requires
- guzzlehttp/guzzle: 7.*
- magento/framework: *
README
Overview
The SimpleMage CacheWarmup module is designed to enhance the performance of your Magento store by automating the process of warming up the cache for your website's pages. This module is compatible with both Magento Full Page Cache and Varnish, ensuring that your store's pages are preloaded into the cache, reducing load times for your visitors.
Using this module you do not need advanced rules or settings in Magento, you can add specific URLs from a file added in the admin panel that are important for your business - the most visited subpages or new products, e.g. 1000-2000 most frequently displayed addresses from Google Analytics or another analytics tool with visit statistics.
It is particularly useful for setups with multiple Varnish servers, as it can handle complex infrastructures seamlessly - without coding.
Key Features
- Compatibility: Works with both Magento Full Page Cache and Varnish.
- URLs from file: Supports cache warmup based on a list of URLs imported from a file (e.g., from Google Analytics) - can warmup custom pages from every module provider e.g. blog module or category pages with filters applied.
- Automated custom file read: If you want to prepare custom automatic file generation with list of URLs you can create your own script and upload file to static path.
- Multi-Server Support: Handles infrastructures with multiple Varnish servers or single Varnish instance.
- Cronjob Integration: Automates cache warmup at scheduled intervals via cronjob.
- SSL Verification: Includes an option to disable SSL verification for local Varnish testing.
Limitations
- Customer group: In this version the module does not support customer groups - it saves pages in the cache only for not logged in clients
- Clean cache: If the server performs a full page cache cleanup, the pages will be saved in the cache only after the cronjob is executed again
Installation
-
Use composer to install
composer require simplemage/magento2-cachewarmup
or download the module files and place them in the app/code/SimpleMage/CacheWarmup
directory within your Magento installation
- Run the following commands to enable the module:
php bin/magento setup:upgrade php bin/magento setup:di:compile php bin/magento cache:flush
- Configure the module via the Magento admin panel under
Stores > Configuration > SimpleMage > Cache Warmup
General Settings
Varnish Server IPs
- if you have multiple Varnish servers put here public IPs of this servers, if you have Varnish installed on the same server (or not have Varnish installed) leave it blankFile source
- select data source (default option isFile upload
) - if you want to create custom script to prepare automatically URLs to warmup please select optionStatic file path
and save your file in Magento system pathvar/import/warmup_urls.txt
File with URLs to warmup
- upload file with URLs you want to warump - supports simple TXT file with URLs separated by new line - you can find example file in repository example-file.txtSkip verify host SSL certificate
- use only on localhost for testing purposes
Cronjob Settings
Enable warmup cronjob
- enable or disable warmup cronjobCron schedule
- cron expression configurationEnable debug mode
- enable debugging of every query for every URL from the file
Troubleshooting
- Cache not warming up properly
If you notice that certain pages are not being cached, follow these steps:
- Enable Debug Mode: Turn on debug mode in the module settings.
- Check Logs: Review the logs to see the status of the requests made by the module.
- If the status is not 200, there may be a connection issue between your Magento application server and the Varnish server(s).
- Ensure that your Magento server can send requests to the public IP address of your Varnish server(s).
- Local Varnish Testing
If you are testing Varnish locally and encountering issues:
- Problem with SSL verification: Use the option in the module settings to disable SSL verification
Stores > Configuration > SimpleMage > Cache Warmup > General Settings > Skip verify host SSL certificate
. This is useful for local environments where SSL certificates may not be properly configured.
Support
For any issues or questions regarding the module, please open an issue on our GitHub repository.