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

ACSD-69237: sales_*_async_insert cron作业每次运行仅处理100个条目

ACSD-69237修补程序修复了以下问题:在将记录插入sales grid表时,sales_*_async_insert cron作业每次只处理100个条目,而不是以批处理方式处理所有挂起行。 安装Quality Patches Tool (QPT) 1.1.77时,此修补程序可用。 修补程序ID为ACSD-69237。 请注意,此问题计划在Adobe Commerce 2.4.9中修复。

受影响的产品和版本

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

  • Adobe Commerce(所有部署方法) 2.4.5-p15

与Adobe Commerce版本兼容:

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

问题

在将记录插入sales网格表时,sales_*_async_insert cron作业每次只处理100个条目,即使存在更多挂起行,也会导致对表(如sales_order_grid)的更新不完整。

重现步骤

  1. 在系统中生成800个订单。

  2. 导航到​Configuration > Advanced > Developer > Grid Settings,启用网格的异步索引。

  3. 验证数据库中的订单计数:

    code language-none
    SELECT COUNT(*) FROM sales_order_grid;
    

    结果应为800。

  4. 删除sales_order_grid表的内容:

    code language-none
    DELETE FROM sales_order_grid;
    
  5. 运行处理sales_*_async_insert队列的cron作业。

  6. 再次检查数据库中的订单计数:

    code language-none
    SELECT COUNT(*) FROM sales_order_grid;
    

预期的结果

所有800个缺失订单都通过单个sales_order_grid cron作业运行插入到sales_grid_order_async_insert表中。

实际结果

在单个sales_order_grid cron作业运行期间,sales_grid_order_async_insert表中只插入800个缺失订单中的100个。

应用修补程序

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

相关阅读

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

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