After doing a diff on the tables from a production server to a local server I have noticed that new tables have been created all ending with _cl
. These are:
# TABLE: catalog_category_product_cl
# TABLE: cataloginventory_stock_cl
# TABLE: catalog_product_price_cl
# TABLE: catalog_product_category_cl
# TABLE: customer_dummy_cl
# TABLE: catalogrule_product_cl
# TABLE: catalog_product_attribute_cl
# TABLE: catalogsearch_fulltext_cl
# TABLE: design_config_dummy_cl
# TABLE: catalogrule_rule_cl
Seeing as these are all related to indexes within Magento, I assume that they are "change Logs" or suchlike (if this could be confirmed I would appreciated it!).
I have a two part question around this, how are these tables populated, and how often / how are these tables cleaned?
Any help on this would be greatly appreciated.
Best Answer
Those tables are related to MView from Magento 2. It's the indexer that runs in cron every minute by default. MView is used if you set the indexer mode to 'Index by Schedule'.
Magento checks if the
_cl
tables exist, if not, are created every time the indexer/MView runs. The code related to these table creation is in\Magento\Framework\Mview\View::subscribe()
.The insertions in these tables are done by MySQL triggers. All triggers in Magento 2 database are used to update
_cl
tables:SHOW TRIGGERS
. If admin changes the price of the product than it will insert rows in some of the tables. When cron runs after 1 minute, it will trigger indexing on those entities for each involved indexer. After each indexer run, if there are entities affected/cache tags (catalog_product_123), it triggers full page cache/Varnish type cleaning._cl
tables rows are deleted if are old, like every hour. There is a cron job for this.Check this: what is mview in magento2?
EDIT Also reset version_id to
0
inmview_state
table. Otherwise it won't reindex until ids in*_cl
tables reach theversion_id
inmview_state
.There may be more
*_cl
tables than this: