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

ACSD-67091:由于大型删除期间的写集大小上限,目录规则产品索引清理失败

ACSD-67091修补程序修复了在大型删除期间,由于最大写集大小而导致目录规则产品索引清理失败的问题。 安装Quality Patches Tool (QPT) 1.1.76时,此修补程序可用。 修补程序ID为ACSD-67091。 请注意,此问题计划在Adobe Commerce 2.4.9中修复。

受影响的产品和版本

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

  • Adobe Commerce(所有部署方法) 2.4.8

与Adobe Commerce版本兼容:

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

问题

在大型删除期间,目录规则产品索引清理失败,并出现最大写集大小错误。

先决条件

您的实例必须具有多个网站、100,000多种产品、多个客户组以及超过20个目录价格规则。

重现步骤

  1. 运行重新索引以生成数据并使用以下命令填充catalogrule_product表:

    code language-none
    bin/magento indexer:reindex catalogrule_product
    
  2. 进行多个目录更改,然后再次运行重新索引。

  3. 请注意,catalogrule_product表是使用单个删除操作清除的。

预期的结果

  1. 已清除大型catalogrule_product表,并且没有问题。
  2. 索引器以可管理的批量删除数据,以避免事务限制。
  3. 在标准索引操作期间,不会发生性能严重下降或故障。

实际结果

  1. 使用影响超过5000万条记录的单个大型删除查询清除catalogrule_product表。
  2. MySQL返回错误: WSREP:超出事务大小限制(2147483647)。
  3. 由于写集大小限制,索引器操作失败。
  4. 由于单个事务中删除了数百万行,数据库性能下降。

应用修补程序

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

相关阅读

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

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