9

我正在使用Java 自带的CORBA (ORB) ,没有使用第三方库。

我需要CORBA 客户端 Properties for timeouts,以便在客户端设置超时并限制连接保持打开的时间量;应该为所有场景设置它,以限制最大请求时间:

  • 初始化连接

  • 重新绑定连接

  • 总请求时间

我正在通过在服务器上休眠(在服务器方法逻辑内)进行测试,并且客户端根本没有超时

在网上很难找到合适的文档;我尝试使用以下所有属性,但无济于事:

aProperties.put("com.sun.CORBA.transport.ORBTCPReadTimeouts", "100:300:3000:20"); aProperties.put("com.sun.corba.eetransport.ORBTCPTimeouts", "500:2000:50:1000"); aProperties.put("com.sun.corba.ee.transport.ORBWaitForResponseTimeout", 10);

为了更清楚起见,在这些属性(上图)旁边是使用属性org.omg.CORBA.ORBInitialHostorg.omg.CORBA.ORBInitialPort设置主机和端口。

任何帮助表示赞赏:)

4

2 回答 2

5

阅读此 Oracle 博客,了解有关超时的更多信息。这对我帮助很大。

com.sun.corba.ee.impl.orbutil.ORBConstants 中有许多 ORB 配置参数(请注意,这是 GlassFish ORB,而不是 JDK ORB)。与传输超时相关的常量是:

  • TRANSPORT_TCP_TIMEOUTS_PROPERTY

这控制了当 ORB 正在读取数据并且没有一次获取所有数据时的重试行为。它是 TcpTimeouts 的一个实例。默认值为 2000:6000:20。

  • TRANSPORT_TCP_CONNECT_TIMEOUTS_PROPERTY

这是与此讨论相关的问题。当尝试连接到 IOR(EJB 引用的连线代表)时,它控制 ORB 在客户端的行为方式。这也是 TcpTimeouts 的一个实例。默认值为 250:60000:100:5000。

  • WAIT_FOR_RESPONSE_TIMEOUT

这控制客户端在成功发送请求后等待响应的时间。默认值为 30 分钟。两个 TcpTimeouts 使用相同的配置语法:

initial:max:backoff[:maxsingle](由 : 分隔的 3 或 4 个正十进制整数的序列)

在哪里:

  • initial是以毫秒为单位的第一个超时
  • max是最大等待时间(在最后一次等待之前,可以超过这个时间),以毫秒为单位
  • 退避是每次增加超时的退避因子(乘法实际上是 (backoff+100)/100,所以 20 是 1.2,100 是 2,但我们在这里避免使用任何浮点数)。这通常应该在 10 到 100 之间。
  • maxsingle是最大单次等待时间。这是可选的,如果未定义,则默认为 Integer.MAX_VALUE。

这工作如下:

第一次超时持续初始毫秒。每个后续超时都是通过乘以退避因子从前一个超时获得的(如上所述) 超时不能超过 maxsingle 毫秒:一旦达到此值,任何后续超时都具有相同的值。在最后一次超时之前花费的总时间小于最大值。请注意,最后一次超时可能会导致总时间超过最大值。

于 2014-10-14T08:46:54.960 回答
3

对于 glassfish 3.1.2.2,我可以确认忽略某些 CORBA 属性中建议的解决方案确实有效。

所需的系统属性可以设置为 java 命令参数

java -Dcom.sun.corba.ee.transport.ORBWaitForResponseTimeout=5000 -Dcom.sun.corba.ee.transport.ORBTCPConnectTimeouts=100:500:100:500 -Dcom.sun.corba.ee.transport.ORBTCPTimeouts=500:2000:50:1000 -cp ..

或在您的代码中

System.setProperty("com.sun.corba.ee.transport.ORBWaitForResponseTimeout","5000");

必须将 ORB 参数设置为系统属性。如果用作 InitialContext 的属性,它们将无效。

于 2013-09-06T12:56:30.620 回答