Skip to main content

How caching is used in Magento

What is Caching?

In computing, a cache is a high-speed data storage layer that stores a subset of data, typically transient in nature, so that future requests for that data are served up faster than is possible by accessing the data’s primary storage location. Caching allows you to efficiently reuse previously retrieved or computed data.

How caching is implemented in Magento?

The Magento page cache library contains a simple PHP reverse proxy that enables full page caching out of the box. A reverse proxy acts as an intermediary between visitors and your application and can reduce the load on your server.

Magento's default caching mechanism provides different storage options that store cached data in 3 different sources:

  • File System
  • Database
  • Redis
There are different types of cache available by default in Magento. You can check here about different types.

Any page new page added to the website is by default cachable. But a developer can make any page uncacheable by adding a small chunk of code in the page layout file.

<block cacheable="false" class="Magento\Customer\Block\Form\Edit" name="customer_edit" template="Magento_Customer::form/edit.phtml">
    <container as="form_additional_info" name="form.additional.info">
</container></block>

NOTE: A developer should always take care that this code should not be added in the default.xml file or any other layout file which is added across the website. Because this code is added in the layout, then that makes the complete page uncacheable.

Different Cache Commands

Magento has provided different commands to execute different cache operations. They are below:

  1. php bin/magento cache:status: This command is used to check the status of the individual cache types.
  2. php bin/magento cache:enable: This command is used to enable the cache. You can pass cache type as parameter in the command as below:
    php bin/magento cache:enable [type] ... [type]
  3. php bin/magento cache:disable: This command is used to disable the cache. You can pass cache type as parameter in the command as below:
    php bin/magento cache:disable [type] ... [type]
  4. php bin/magento cache:clean: This command is used to clear the cache. You can pass cache type as parameter in the command as below:
    php bin/magento cache:clean [type] ... [type]
  5. php bin/magento cache:flush: This command is used to remove the cache. You can pass cache type as parameter in the command as below:
    php bin/magento cache:flush [type] ... [type]

NOTE: The type option is a space-separated list of cache types.

Difference Between Cache Clean & Cache Flush

  • Cache Clean: This command deletes all the enabled magento related cache. And does not impact the other stored data in the same storage.
  • Cache Flush: This command deletes all the magento related cache and also delete all the other stored data in the same storage. This might impact the other applications which are using the same storage for caching.

Comments

Popular posts from this blog

Unlocking Success: The Vital Role of the Contact Us Page in E-commerce

In the dynamic realm of e-commerce, where digital transactions reign supreme, the significance of customer communication cannot be overstated. Amidst the plethora of factors influencing the success of an online store, one often overlooked yet fundamentally important element is the Contact Us page. This seemingly humble corner of a website holds immense power, serving as a linchpin in fostering trust, resolving issues, and nurturing customer relationships. Let's delve deeper into why the Contact Us page is not just an afterthought but a strategic asset for e-commerce businesses, backed by proven data. Building Trust and Credibility Trust is the cornerstone of any successful e-commerce venture. According to a survey conducted by Edelman, 81% of consumers say that trusting a brand to do what is right is a deciding factor in their purchasing decisions. A prominently displayed Contact Us page with clear contact information, including a physical address, phone number, and email address, ...

Magento - LogRocket Integration

In today’s competitive eCommerce landscape, understanding user behavior is crucial for optimizing customer experiences and improving conversion rates. Magento 2, a powerful and flexible eCommerce platform, allows merchants to customize their online stores extensively. However, monitoring how users interact with these customizations is often challenging. This is where LogRocket, a modern session replay tool, comes into play. Integrating LogRocket with Magento 2 can provide invaluable insights into user behavior, performance bottlenecks, and UX issues. In this blog post, we’ll walk you through the steps to integrate LogRocket with Magento 2, and how this integration can help you improve your store’s performance and user experience. What is LogRocket? LogRocket is a session replay tool that enables you to record and playback user activity on your website. It tracks interactions such as clicks, scrolls, and form inputs, giving you a clear view of how users navigate your store. In addition,...

Magento 2: How to enable cache for a custom EAV attributes?

To prepare for the certification exam, the candidate should know about different cache types and their purpose. The cache is an important and crucial part of the website's performance. One of the caches is the "EAV types and attributes" cache. You can check the list of caches in Magento Admin and by using console commands. Below is the screenshot of the list of caches in admin under System -> Cache Management As of version 2.3.4, Commerce caches all system EAV attributes as they are retrieved. Caching EAV attributes in this manner improves performance, because it decreases the amount of insert/select requests to the DB. However, it increases cache network size as well. Developers can cache custom EAV attributes by running the below command. bin/magento config:set dev/caching/cache_user_defined_attributes 1 This can also be done from the Admin while in Developer mode by setting Stores > Settings Configuration > Advanced > Developer > Caching Settings > Ca...