[仅限PaaS]{class="badge informative" title="仅适用于云项目(Adobe管理的PaaS基础架构)和内部部署项目上的Adobe Commerce 。"}
ACSD-62577:店面搜索性能优化
ACSD-62577修补程序通过优化查询和表索引来修复店面搜索查询性能缓慢的问题。 此修补程序在Quality Patches Tool (QPT) 1.1.56中可用。修补程序ID为ACSD-62577。 请注意,该问题计划在Adobe Commerce 2.4.8中修复。
受影响的产品和版本
为Adobe Commerce版本创建了修补程序:
Adobe Commerce(所有部署方法) 2.4.6、2.4.7-p2
与Adobe Commerce版本兼容:
Adobe Commerce(所有部署方法) 2.4.4 - 2.4.7-p3
magento/quality-patches包更新到最新版本,并在Quality Patches Tool:搜索修补程序页面上检查兼容性。 使用修补程序ID作为搜索关键字来查找修补程序。问题
大的search_query表显着减慢店面搜索速度,由于查询效率低下和缺少优化的表索引,增加了前端响应时间。
重现步骤:
-
使用性能工具包
small.xml设置Adobe Commerce Develop。 -
访问SQL命令行并使用以下命令删除
search_query表:code language-none SET FOREIGN_KEY_CHECKS = 0; DROP TABLE search_query; SET FOREIGN_KEY_CHECKS = 1; -
使用大量记录填充
search_query表,例如: 400万条记录。 -
触发重新索引和刷新缓存。
code language-none bin/magento indexer:reindex bin/magento c:c bin/magento c:f -
启用数据库调试日志:
code language-none bin/magento dev:query-log:enable -
在店面搜索栏中搜索术语,例如,
http://your_magento_instance/default/catalogsearch/result/?q=test. -
检查
db.log以了解以下SQL的查询执行时间:code language-none SELECT COUNT(*) FROM ( SELECT DISTINCT `main_table`.`query_text` FROM `search_query` AS `main_table` WHERE (main_table.store_id IN (1)) AND (main_table.num_results > 0) ORDER BY `main_table`.`popularity` DESC LIMIT 100 ) AS `result` WHERE (result.query_text = 'test')
预期的结果:
查询执行时间已得到优化,在处理大型search_query表时,导致响应时间的增加不太显着。
实际结果:
由于处理大型search_query表的效率较低,查询执行时间显着增加:
TIME: 10.8520 seconds
应用修补程序
要应用单独的修补程序,请根据您的部署方法使用以下链接:
- Adobe Commerce或Magento Open Source内部部署: Quality Patches Tool 指南中的>使用情况Quality Patches Tool。
- 云基础架构上的Adobe Commerce:云基础架构上的Commerce指南中的升级和修补程序>应用修补程序。
相关阅读
要了解有关Quality Patches Tool的更多信息,请参阅: