MySQLデータベースに接続するTomcat6で実行されているJavaプロジェクトに取り組んでいます。お客様のサーバーでのテストとしてローカルでテストする場合は、すべての手順が正常に実行されます。ただし、例外が1つあります。これは、レポートを生成するために大量のデータを取得する1つのプロシージャの場合です。MySQLから実行する場合、ストアドプロシージャは13分ほどかかります。アプリケーションをローカルで実行してオンラインデータベースに接続すると、手順は機能しますが、機能しないのは、クライアントのサーバーで実行した場合のみです。
クライアントはサーバーをかなり保護しているため、サーバーの制御は制限されていますが、問題の解決を求めています。ログファイルを確認すると、ストアドプロシージャを実行する関数からエラーがスローされることはありません。そして、コードにいくつかのデバッグログを入れると、execute呼び出しに到達することを示していますが、呼び出しの直後にデバッグをログに記録せず、catchにエラーを記録せず、finallyセクションに入ります。
彼らは、MySQLログにタイムアウトエラーがないと主張しています。
何がこの問題を引き起こす可能性があるかについて誰かが何か考えを持っているなら、どんな助けでもありがたいです。
更新:
サーバー管理者に少し話しかけた後、私はついにカタリナログにアクセスできるようになりました。それらのログで、私はついに何らかの意味を持つエラーを見つけました。
Exception in thread "Thread-16" java.lang.OutOfMemoryError: Java heap space
at java.util.Arrays.copyOf(Arrays.java:2894)
at java.lang.AbstractStringBuilder.expandCapacity(AbstractStringBuilder.java:117)
at java.lang.AbstractStringBuilder.append(AbstractStringBuilder.java:407)
at java.lang.StringBuffer.append(StringBuffer.java:241)
at be.playlane.mink.database.SelectExportDataProcedure.bufferField(SelectExportDataProcedure.java:68)
at be.playlane.mink.database.SelectExportDataProcedure.extractData(SelectExportDataProcedure.java:54)
at org.springframework.jdbc.core.JdbcTemplate.processResultSet(JdbcTemplate.java:1033)
at org.springframework.jdbc.core.JdbcTemplate.extractReturnedResultSets(JdbcTemplate.java:947)
at org.springframework.jdbc.core.JdbcTemplate$5.doInCallableStatement(JdbcTemplate.java:918)
at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:876)
at org.springframework.jdbc.core.JdbcTemplate.call(JdbcTemplate.java:908)
at org.springframework.jdbc.object.StoredProcedure.execute(StoredProcedure.java:113)
at be.playlane.mink.database.SelectExportDataProcedure.execute(SelectExportDataProcedure.java:29)
at be.playlane.mink.service.impl.DefaultExportService$ExportDataRunnable.run(DefaultExportService.java:82)
at java.lang.Thread.run(Thread.java:636)
これがアプリケーションログに記録されないのは奇妙なことですが、trycatchにラップされている場合でも同様です。エラーに基づくと、問題はこのメソッドにあります。
public Object extractData(ResultSet rs) throws SQLException, DataAccessException
{
StringBuffer buffer = new StringBuffer();
try
{
// get result set meta data
ResultSetMetaData meta = rs.getMetaData();
int count = meta.getColumnCount();
// get the column names; column indices start from 1
for (int i = 1; i < count + 1; ++i)
{
String name = meta.getColumnName(i);
bufferField(name, i == count, buffer);
}
while (rs.next())
{
// get the column values; column indices start from 1
for (int i = 1; i < count + 1; ++i)
{
String value = rs.getString(i);
bufferField(value, i == count, buffer);
}
}
}
catch (Exception e)
{
logger.error("Failed to extractData SelectExportDataProcedue: ", e);
}
return buffer.toString();
}
private void bufferField(String field, boolean last, StringBuffer buffer)
{
try
{
if (field != null)
{
field = field.replace('\r', ' ');
field = field.replace('\n', ' ');
buffer.append(field);
}
if (last)
{
buffer.append('\n');
}
else
{
buffer.append('\t');
}
}
catch (Exception e)
{
logger.error("Failed to bufferField SelectExportDataProcedue: ", e);
}
}
これらの機能の目的は、特定の結果セットをExcelファイルにエクスポートすることです(これはより高いレベルで発生します)。
したがって、これを最適化するためのヒントがあれば、大歓迎です。