Datahub启动失败,因为池大小超过了最大限制

2020-09-23 12:08发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)大家好,最近我们遇到了以下问题-...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


大家好,最近我们遇到了以下问题-

2018-03-02 23:58:34,607 [错误] [chdaePoolEventHandler]无法启动数据中心java.lang.RuntimeException:要在池此处的池名中发布的项目数超过了限制 由datahub.init.publishable.items.query.limit属性提供的100000。 请以创建-拖放模式重新启动Data Hub并重新发送或以标准模式重新启动Data Hub并在此处池名触发池的发布。 在com.hybris.datahub.lifecycle.ReinitializeCanonicalCacheHandler.initializePool(ReinitializeCanonicalCacheHandler.java:60)〜[datahub-in-memory-6.6.0.0-RC4.jar:6.6.0.0-RC4]

当我们将datahub.init.publishable.items.query.limit的值修改为更大的值时,此问题得到解决。 先前它使用默认值'10000',但是在尝试分析根本原因时,注意到以下内容

  1. 大多数状态为"成功"的规范项都在CanonicalItem表中。 尽管启用了以下属性,但没有被删除。 datahub.cleanup.publisheditems.enabled = true

  2. 池中的项目数由多少组成? 它是该池中原始和规范项的总数吗? 因为我们使用IN_MEMORY配置模式,所以不会保留目标项目。

  3. 是否可以通过API检查池大小以进行监视? 一旦接近阈值,我们就可以手动删除已处理的原始和规范项目。 还有其他更好的解决方案来避免此问题吗? 请提出建议。

11条回答
三十六小时_GS
2020-09-23 12:20

运行清理时,您应该会看到类似以下内容的

  [INFO] [com.hybris.datahub.cleanup.jdbc.AbstractJdbcCleanupService]成功发布的项目清理:[从`CanonicalItem` WHERE`id` IN(:ids)中删除]:x记录已删除
  [INFO] [com.hybris.datahub.cleanup.jdbc.AbstractJdbcCleanupService]成功发布的项目清理:[从`PublicationError`中删除`canonicalitempublicationstatus` IN(:secondaryids)]:x记录已删除
  [INFO] [com.hybris.datahub.cleanup.jdbc.AbstractJdbcCleanupService]成功发布的项目清理:[从`CanItemPubStatus`中的`id` IN(:secondaryids)中删除]:删除了x条记录
  

但是,正如我之前所说,该池中没有要删除的清理内容。 该池会累积未发布的项目,而清理只会删除已经发布的项目。

通过将POST发送到/pools/{poolName}/publications,尝试手动启动该池中的发布。 该主体应包含要发布的目标系统。 例如, {" targetSystemPublications":[{" targetSystemName":" name_of_the_target_system"}]} 。 可以从该池的 target.system.publication.configuration 属性的值中获取 name_of_the_target_system

您可以对同一URL使用GET请求来检查发布状态。 请参阅REST API以跟踪详细信息。 此外,日志中还将打印出信息。