JBoss事务超时设置?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JBoss事务超时设置?相关的知识,希望对你有一定的参考价值。
我们在JBoss 5.1.0.GA应用程序中有一个定时器服务触发任务,问题是我们无法改变事务超时。这个长Lucene索引可能需要比默认的300秒限制更长的时间。
问题是如何更改超时值,将@TransactionTimeout(1800)添加到worker方法或类没有任何效果。
编辑:在deploy / transaction-jboss-beans.xml中设置此工作正常:
<property name="transactionTimeout">1800</property>
但是注释似乎对定时器启动的或正常的无状态EJB没有影响。
我正在使用EJB3和Jboss 5.1.0.GA并在JBOSS_HOME/deploy/transaction-jboss-beans.xml
中成功设置了这个值。
<property name="transactionTimeout">300</property>
的默认值为300
尝试在jboss-service.xml中设置:
<!-- JBoss Transactions JTA -->
<mbean code="com.arjuna.ats.jbossatx.jta.TransactionManagerService"
name="jboss:service=TransactionManager">
<attribute name="TransactionTimeout">120</attribute> <!-- timeout in seconds-->
<attribute name="ObjectStoreDir">${jboss.server.data.dir}/tx-object-store</attribute>
</mbean>
这是基于服务器的配置,因此请在服务器目录下查找conf / jboss-service.xml。
您可以手动声明超时时间并在会话Bean中创建计时器。
下面是我的无状态Bean的示例代码:
public void createTimer(String timerName) {
//...
sessionContext.getTimerService().createTimer(timeLongValue, timerName);
//...
}
@Timeout
public void timeOutHandler(Timer timer){
// code
}
TransactionTimeout是MDB吗?他们有不同的注释。该链接提供了通过配置文件上的代码设置转换超时的各种选项。
事务超时,JBOSS EAP 7.1版本的默认设置为300。
添加此行(<coordinator-environment enable-tsm-status="true" default-timeout="1200"/>
)在路径“..standalone / configuration / standalone.xml”中添加配置文件
....
<subsystem xmlns="urn:jboss:domain:transactions:4.0">
<core-environment>
<process-id>
<uuid/>
</process-id>
</core-environment>
<recovery-environment socket-binding="txn-recovery-environment" status-socket-binding="txn-status-manager"/>
<coordinator-environment enable-tsm-status="true" default-timeout="1200"/>
<object-store path="tx-object-store" relative-to="jboss.server.data.dir"/>
</subsystem>
在<blocking-timeout-millis>
元素中指定事务超时。此元素指示在等待连接时和显示异常之前阻止事务的最长时间(以毫秒为单位)。这仅在等待连接许可时阻塞,并且在创建需要非常长时间的新连接时不显示异常。
<subsystem xmlns="urn:jboss:domain:datasources:4.0">
<datasources>
<datasource jndi-name="java:jboss/xyz" pool-name="abc" enabled="true" use-java-context="true">
<connection-url>jdbc:sqlserver://xx.xx.xxx.xxx:1433;databaseName=xxxx</connection-url>
<driver>SQLServerDriver</driver>
<transaction-isolation>TRANSACTION_READ_COMMITTED</transaction-isolation>
<pool>
<min-pool-size>50</min-pool-size>
<max-pool-size>150</max-pool-size>
<prefill>false</prefill>
</pool>
<security>
<user-name>xxx</user-name>
<password>xxx</password>
</security>
<timeout>
<blocking-timeout-millis>36000</blocking-timeout-millis>
</timeout>
</datasource>
<datasource jndi-name="java:jboss/datasources/ExampleDS" pool-name="ExampleDS" enabled="true" use-java-context="true">
<connection-url>jdbc:h2:mem:test;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE</connection-url>
<driver>h2</driver>
<security>
<user-name>sa</user-name>
<password>sa</password>
</security>
</datasource>
<drivers>
<driver name="SQLServerDriver" module="com.microsoft.sqlserver">
<xa-datasource-class>com.microsoft.sqlserver.jdbc.SQLServerDataSource</xa-datasource-class>
</driver>
<driver name="h2" module="com.h2database.h2">
<xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
</driver>
</drivers>
</datasources>
</subsystem>
与Jboss无关,但您可以通过com.arjuna.ats.arjuna.coordinator.defaultTimeout = 60属性设置arjuna事务超时。
以上是关于JBoss事务超时设置?的主要内容,如果未能解决你的问题,请参考以下文章