2

JTOpen ProgramCall クラス (com.ibm.as400.access.ProgramCall) を使用して、IBM i (AS/400) 上のプログラムを呼び出す Web アプリ (Tomcat で実行) に取り組んでいます。私の問題は、応答に 30 秒以上かかるプログラム呼び出しで、java.net.SocketTimeoutException: Read timed out exception.

このクラスで使用できるメソッドがあり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());
}
4

1 に答える 1

3

さて、さらに数時間後、解決策を見つけました。元の開発者socket timeoutが JDBC 接続文字列にパラメーターを追加したようです。パラメーターを削除するだけで、デフォルト値が0、または無限のタイムアウトになるため、うまくいきました。

前:

String connectionStr = "jdbc:as400://" + systemInfo.getIPAddress() + ":1527" + ";naming=system;socket timeout=30000;thread used=false;errors=full;prompt=false;date format=iso;block size=128;transaction isolation=none;user=" + systemInfo.getUserName() + ";password=" + systemInfo.getPassword();

後:

String connectionStr = "jdbc:as400://" + systemInfo.getIPAddress() + ":1527" + ";naming=system;thread used=false;errors=full;prompt=false;date format=iso;block size=128;transaction isolation=none;user=" + systemInfo.getUserName() + ";password=" + systemInfo.getPassword();

:\

于 2016-04-04T21:49:27.143 に答える