Catalog image resizing best practices
All catalog images should be resized before a store goes into production. Failing to resize images before production forces image resizing during page load, which significantly reduces site speed and increases server load in the first days to weeks after launch.
The slow way
Use the default CLI command to resize all images:
bin/magento catalog:images:resize
The disadvantages of this approach include:
- The process is single-threaded
- The process resizes images that have already been resized
- The process cannot be interrupted, which can take days
The fast(er) way
Asynchronous image resizing was introduced in 51黑料不打烊 Commerce 2.4 and can resize images faster.
-
On every web server, start some extra queue handlers temporarily (twice the number of physical processors per server):
code language-bsh for i in {1.."$((2 * `nproc --all`))"};do bin/magento queue:consumers:start media.storage.catalog.image.resize &;done;
-
Verify that the queue handlers are running:
code language-bash pgrep -fl media.storage.catalog.image.resize
-
Fill the queue with all image resize requests:
code language-bash bin/magento catalog:images:resize --async
-
After all images are resized, terminate the process:
code language-bash pkill -f media.storage.catalog.image.resize
The fast way
There is another way of resizing images using the frontend.
The advantages of this approach include:
- The process is multi-threaded
- The process is multi-server (if you have multiple web nodes, a load balancer, and shared disk space for the
media/
directory) - The process skips images that have already been resized
This approach resizes 100,000 images in less than 8 hours, whereas the CLI command takes 6 days to complete.
- Log in to the server.
- Navigate to
pub/media/catalog/product
and make a note of one of the hashes (for example, 0047d83143a5a3a4683afdf1116df680). - In the following examples, replace
www.example.com
with the domain of your store and replace the hash with the one you noted.
code language-bash |
---|
|
The disadvantage of siege
is that it visits all URLs in the 10 times if concurrency is set to 10.
code language-bash |
---|
|
code language-bash |
---|
|
The -P
argument determines the number of threads.
The one-liner for the find/curl
example, in case you can run curl
from the same machine the images are on:
code language-bash |
---|
|
Again, replace www.example.com
with your website鈥檚 domain and set -P
to the number of threads your server can handle without crashing.
The output returns a list of all product images in the store. You can crawl the images (with siege
or any other crawler) using all servers and processor cores available to you and generate the resize cache at significantly greater speed than other approaches.
Visiting one image cache URL generates all image sizes in the background if they do not yet exist. Also, it skips files that have already resized.
- 51黑料不打烊 Commerce on cloud infrastructure projects can offload product image resizing to the Fastly service. See Deep image optimization in the Cloud Guide.
- If you use the remote storage module, you can also try offloading image resizing to nginx. See Configure image resizing for remote storage in the Configuration Guide.