メモリリーク(?)時にSQLException
初めて質問させていただきます。
java+mysqlでWebアプリを作成しているのですが、DBからデータ取得後、取得結果をStringに格納するところで2回に1回だけエラーとなってしまいます。
具体的には下記のようなプログラム実行時にSQLExceptionが出てしまいます。
// ---- プログラム
// ・・・(略)・・・
String str = "";
rs = pst.executeQuery();
while (rs.next())}
str = str + rs.getString("name");
}
// ---- 出力されるエラー(途中まで)
java.sql.SQLException: Operation not allowed after ResultSet closed
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910)
at com.mysql.jdbc.ResultSet.checkClosed(ResultSet.java:644)
at com.mysql.jdbc.ResultSet.next(ResultSet.java:6663)
ResultSetがクローズされてるよというエラーだと思うのですが、
str = str + rs.getString("name");
のところを
str = rs.getString("name");
に書き換えた場合と、String型ではなくStringBufferでappendを使って文字列連結させていった場合はエラーになりません。
また、ログを入れて動作状況を確認してみたところwhile文は何回かは動いているようです。
※while文は5000回以上ループし、strは最終的にかなり大きいサイズになります。
このような状況を考えると、メモリリークが発生して落ちているのかと思うのですが、発生しているエラー内容は上記の通りSQLExceptionです。
また、一番腑に落ちないのはこのエラーが2回に1回だけ出る、ということです。
同じような現象をご存知の方がいらっしゃいましたら、何が起こっているのか教えていただけないでしょうか?
未熟ながら私の予想ですと、メモリリークが発生する前にjavaがGCでメモリクリアしようとしているんだけど、そのときにResultSetも一緒に消しちゃってる・・・?
javaやjdbcのバグ???とも考えているのですが、どうやって確認したらいいのかわからず困っています。
No.2ベストアンサー
- 回答日時:
java のgcがResultSetを消しちゃうと言う様な話は、聞いた事がありませんが、
ResultSet自体が、時間切れや、過負荷時に、自動的にクローズされると言う
事なら、ありえるかと思います。
ResultSet自体の実装として、TCP/IP等による、ソケット接続を内部的に行っ
ている可能性がありますからねぇ。
>ResultSet自体が、時間切れや、過負荷時に、自動的にクローズされると言う
>事なら、ありえるかと思います。
なるほど。
1/2の確立でしかエラー発生しないことを考えると可能性としては低い気もしますが、その線で調べてみます。ありがとうございます!
No.5
- 回答日時:
> 変数rsは使う前に毎回初期化していますので、問題ないかと思います。
どう初期化しているのかわからないけど
「~思います」がついているうちは疑ってかかるわよ。
私はResultSetの使い方を疑っているわ。
closeされた後のResultSetに対し何かやっているんじゃないか、ってね。
そのひとつが変数rsの再利用だったわけ。
もう一度、なにか思い込みでやっているところがないか
見直してみるべきよ。
No.4
- 回答日時:
PreparedStatementを使い回ししている可能性はありませんか?
参考URLより:
デフォルトでは、Statement オブジェクトごとに 1 つの ResultSet オブジェクトだけが同時にオープンできます。
rsやpstがスレッドセーフでは無いのに、他のスレッドから(他のリクエストから)サーブレットが呼ばれていませんか?
参考URL:http://java.sun.com/javase/ja/6/docs/ja/api/java …
No.1
- 回答日時:
>while (rs.next())
rsはResultSetクラスですかね。java.sql のクラスは使ったことがないけど、
Iteratorを実装しているなら、次が有るかどうかは、hasnext() でチェックして、
次があれば、ifブロック内で next() でobject を得て作業という手順のはず。
次があるかのチェックもしないで、next() を繰り返せば、当然いつかは、「データを得られなかった → Operation not allowed after ResultSet closed」というエラーになる。
この回答への補足
回答ありがとうございます。
また、説明不足で申し訳ありません。ご指摘の通り、rsはResultSetです。
しかし、ResultSetはnext()で次が無かったらfalseを返すので、
>while (rs.next())
は問題ないかと思います。
ご指摘にあるように「いつか必ずエラーになる」のではなく、2回に1回のみエラーになっています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・「I love you」 をかっこよく翻訳してみてください
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・昔のあなたへのアドバイス
- ・かっこよく答えてください!!
- ・あなたが好きな本屋さんを教えてください
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・【大喜利】【投稿~8/27】 こんなガソリンスタンド二度と来るか!なぜそう思った?
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・【お題】動物のキャッチフレーズ
- ・【お題】甲子園での思い出の残し方
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・自分用のお土産
- ・人生で一番お金がなかったとき
- ・一番好きなみそ汁の具材は?
- ・泣きながら食べたご飯の思い出
- ・ちょっと先の未来クイズ第1問
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Eclipseで、プロジェクト名のと...
-
エラー:org.springframeworkが...
-
eclipseをバージョンアップした...
-
Javaのエラーについてです
-
重複jarの調査の仕方
-
JSP NullPointerException
-
【サーブレットのコンパイルエ...
-
eclipseでのsvn認証エラー回避方法
-
シンボルが見つかりませんとい...
-
2バイト文字を含むXMLファイル...
-
タグが閉じてないというエラー...
-
javaw.exeプロセスが正常起動し...
-
JAVAを使ったメール送信が時々...
-
Tomcat起動時のエラー
-
java eclipse apache tomcat 9....
-
JBossについて
-
構文エラーのやり直しについて
-
enum列挙子に使える文字列と使...
-
Transformのエラー
-
Eclipseの環境について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Eclipseで、プロジェクト名のと...
-
タグが閉じてないというエラー...
-
シンボルが見つかりませんとい...
-
コンパイル時にエラーが出てし...
-
エラー:org.springframeworkが...
-
JSP内でString型からint型に変...
-
Javaのエラーについてです
-
eclipseでのsvn認証エラー回避方法
-
Eclipseで次のエラー箇所にジャ...
-
構文エラーのやり直しについて
-
tomcat起動時エラー
-
Eclipseの環境について
-
eclipseをバージョンアップした...
-
DataSetのFilter
-
getParameterについて
-
JSPのIF文を教えて下さい
-
struts-config.に対する読み込...
-
Hot code replace failed ?
-
jspのファイルでエラーが出る
-
JBossについて
おすすめ情報