问题描述
我们有一个应用程序,它是由某些EJB触发的批处理过程。该应用程序在wildfly14上运行。
事务/批处理过程可能要花一些时间,因此我们必须配置standalone.xml,以便事务收割者不会杀死我们长期存在的事务。
我们使用此配置作为参考:
<subsystem xmlns="urn:jboss:domain:transactions:5.0">
<core-environment node-identifier="${jboss.tx.node.id:1}">
<process-id>
<uuid/>
</process-id>
</core-environment>
<recovery-environment socket-binding="txn-recovery-environment" status-socket-binding="txn-status-manager"/>
<object-store path="tx-object-store" relative-to="jboss.server.data.dir"/>
<coordinator-environment default-timeout="7200" />
</subsystem>
这似乎可以处理长达一小时的交易。但是在那之后,交易还是被终止了。
超时值似乎适用于小于或等于3600的值。如果将值设置为1800,则恰好在1800秒后终止事务。但是,似乎存在某种上限,因此即使我们将值设置为大于3600,它也始终使用3600。
这3600个值是否经过硬编码?它来自其他地方吗?如何为超时使用更大的值?甚至完全禁用交易收割者?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)