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

ACSD-63687:由于Redis缓存清理问题,显示的价格不正确

ACSD-63687修补程序修复了以下问题:Redis缓存垃圾回收器在LUA模式下运行时,显示的价格不正确,从而导致出现争用情况。 安装Quality Patches Tool (QPT) 1.1.77时,此修补程序可用。 修补程序ID为ACSD-63687。 请注意,此问题计划在Adobe Commerce 2.4.9中修复。

受影响的产品和版本

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

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

与Adobe Commerce版本兼容:

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

问题

显示的价格不正确,因为Redis缓存清理失败。

重现步骤

  1. 为Adobe Commerce环境配置Redis。

  2. 在店面中创建多个产品类别。

  3. 创建将定期请求发送到类别页面的脚本。 使用JMeter脚本或等效的负载测试工具。

  4. 当脚本将请求发送到类别页面时,请执行block_html缓存清除并多次运行backend_clean_cache cron作业。

  5. 执行提供的脚本以识别MAGE缓存集中不存在的Redis缓存键记录。 更新Redis端口和MAGE缓存标记前缀以匹配本地项目配置。

    code language-none
    #!/bin/bash
    
    REDIS_PORT=6379
    REDIS_DB=0
    SET_NAME="zc:ti:af6_MAGE"
    
    redis-cli -p $REDIS_PORT -n $REDIS_DB keys "zc:k:*" | while read KEY; do
      STRIPPED_KEY=${KEY#"zc:k:"}
      EXISTS=$(redis-cli -p $REDIS_PORT -n $REDIS_DB sismember "$SET_NAME" "$STRIPPED_KEY")
    
      if [ "$EXISTS" -eq 0 ]; then
        TIMESTAMP=$(redis-cli -p $REDIS_PORT -n $REDIS_DB hget "$KEY" "m")
    
        if [ -n "$TIMESTAMP" ]; then
          FORMATTED_TIME=$(date -r "$TIMESTAMP" +"%y-%m-%d %H:%M:%S")
          echo "$KEY - m: $FORMATTED_TIME"
        else
          echo "$KEY - m: (null)"
        fi
      fi
    done
    

预期的结果

未在Redis中创建没有相应记录的缓存键,backend_clean_cache Cron作业正确清理缓存条目。

实际结果

缓存键是在Redis中创建的,没有相应的记录,因此backend_clean_cache cron触发的缓存清理不起作用。

应用修补程序

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

相关阅读

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

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