[仅限PaaS]{class="badge informative" title="仅适用于云项目(Adobe管理的PaaS基础架构)和内部部署项目上的Adobe Commerce 。"}

ACSD-68040:MariaDB 10.6上的前端搜索页面速度减慢,且历史记录较大

ACSD-68040修补程序修复了在MariaDB 10.6上运行并具有大量历史搜索请求时,前端搜索页面性能显着下降的问题。 安装Quality Patches Tool (QPT) 1.1.72时,此修补程序可用。 修补程序ID为ACSD-68040。

受影响的产品和版本

为Adobe Commerce版本创建了修补程序:

  • Adobe Commerce(所有部署方法) 2.4.6-p12

与Adobe Commerce版本兼容:

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

问题

处理大量历史搜索请求时,前端搜索页面在MariaDB 10.6显着减慢。 在search_query 10.6中,MariaDB表上的查询耗时13秒,而在MariaDB 11.4中,查询耗时0.5秒。

重现步骤

  1. 安装带有MariaDB 10.6的干净实例以进行测试。

  2. 使用200万个条目填充search_query表。

  3. 执行以下SQL查询:

    code language-none
    SELECT COUNT(*) FROM (
        SELECT `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 = 'seed_q_0000009');
    
  4. 请注意,完成查询大约需要13秒。

  5. 将数据库升级到MariaDB 11.4。

  6. 重新执行相同的SQL查询:

    code language-none
    SELECT COUNT(*) FROM (
        SELECT `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 = 'seed_q_0000009');
    
  7. 请注意,查询现在大约在0.4-0.5秒内完成。

预期的结果

应优化查询或表结构,以确保执行时间最短,而无论MariaDB版本如何。

实际结果

在MariaDB 10.6上,查询大约需要13-15秒;在MariaDB 11.4上,查询大约需要0.4-0.5秒。

应用修补程序

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

相关阅读

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

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