gpt4 book ai didi

java - JTOpen 程序调用套接字超时

转载 作者:行者123 更新时间:2023-11-30 02:59:17 25 4
gpt4 key购买 nike

我正在开发一个 Web 应用程序(在 Tomcat 上运行),该应用程序使用 JTOpen ProgramCall 类 (com.ibm.as400.access.ProgramCall) 调用 IBM i (AS/400) 上的程序。我的问题是程序调用需要超过 30 秒才能响应,这会触发 java.net.SocketTimeoutException:读取超时异常

此类有一个 setTimeout() 方法,但它似乎对套接字超时没有影响。我还检查了我的 Tomcat 配置,没有发现任何会导致此行为的情况。

有谁知道改变这种实现的超时的方法吗?

代码:

pgmCall.setProgram(getCompleteName(), parmList);
initializeAS400TextParameters();

// Run the AS/400 program.
try {
Trace.setTraceDiagnosticOn(true);
Trace.setTraceInformationOn(true);
Trace.setTraceWarningOn(true);
Trace.setTraceErrorOn(true);
Trace.setTraceDatastreamOn(true);

if (pgmCall.run() != true) {
messageList = pgmCall.getMessageList();
for (int i = 0; i < messageList.length; i++) {
log.debug("Error Message " + i + " " + messageList[i]);
}
setCompletionMsg("Program call failed.");
log.debug("442 Program call failed.");

return false;
} else {
messageList = pgmCall.getMessageList();
for (int i = 0; i < messageList.length; i++) {
log.debug("Success Message " + i + " " + messageList[i]);
}
setCompletionMsg("Program called ok.");
log.debug("452 Program called ok.");

return true;
}
} catch (Exception e) {
// This is where the timeout exception is thrown
log.debug("Error Running Program: " + e.getMessage() + " " + e.getLocalizedMessage());
setCompletionMsg(e.getMessage());
}

最佳答案

好吧,又过了几个小时,我找到了解决方案。显然,原始开发人员在 JDBC 连接字符串中添加了一个 socket timeout 参数 - 只需删除该参数即可解决问题,因为默认值为 0 或无限超时。

之前:

String connectionStr = "jdbc:as400://"+ systemInfo.getIPAddress() + ":1527"+ ";naming=system;socket timeout=30000;threadused=false;errors=full;prompt =false;日期格式=iso;区 block 大小=128;交易隔离=none;user="+ systemInfo.getUserName() + ";password="+ systemInfo.getPassword();

之后:

String connectionStr = "jdbc:as400://"+ systemInfo.getIPAddress() + ":1527"+ ";naming=system;使用的线程=false;errors=full;prompt=false;日期格式=iso; block 大小=128;交易隔离=none;user="+ systemInfo.getUserName() + ";password="+ systemInfo.getPassword();

:\

关于java - JTOpen 程序调用套接字超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36362402/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com