[仅限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

NOTE
该修补程序可能适用于具有新Quality Patches Tool发行版本的其他版本。 要检查修补程序是否与您的Adobe Commerce版本兼容,请将magento/quality-patches包更新到最新版本,并在Quality Patches Tool:搜索修补程序页面上检查兼容性。 使用修补程序ID作为搜索关键字来查找修补程序。

问题

大的search_query表显着减慢店面搜索速度,由于查询效率低下和缺少优化的表索引,增加了前端响应时间。

重现步骤

  1. 使用性能工具包small.xml设置Adobe Commerce Develop。

  2. 访问SQL命令行并使用以下命令删除search_query表:

    code language-none
    SET FOREIGN_KEY_CHECKS = 0;
    DROP TABLE search_query;
    SET FOREIGN_KEY_CHECKS = 1;
    
  3. 使用大量记录填充search_query表,例如: 400万条记录。

  4. 触发重新索引和刷新缓存。

    code language-none
    bin/magento indexer:reindex
    bin/magento c:c
    bin/magento c:f
    
  5. 启用数据库调试日志:

    code language-none
    bin/magento dev:query-log:enable
    
  6. 在店面搜索栏中搜索术语,例如,
    http://your_magento_instance/default/catalogsearch/result/?q=test.

  7. 检查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

应用修补程序

要应用单独的修补程序,请根据您的部署方法使用以下链接:

相关阅读

要了解有关Quality Patches Tool的更多信息,请参阅:

recommendation-more-help
c2d96e17-5179-455c-ad3a-e1697bb4e8c3