###前提・実現したいこと
Javaで、特定の文字列が1つのDBテーブル上に存在するかを検索する機能を作っています。
検索のリクエストを投げるアプリサーバと、DBサーバは物理的に別です。
検索にはibatisを使用しており、検索する文字列をibatisのテンプレートに渡し、その戻り値を取得しています。
###発生している問題・エラーメッセージ
検索をループさせる回数が増えれば増えるほど、検索結果の戻り値を得るまでの間隔が伸びています。
100万回のループになると、完了までに4時間以上を要します。
ibatisを使用したDBの大量ループ検索において、このように、スループットが徐々に下がるような事例はありませんでしょうか?
また、その原因をご教示いただけると幸いです。
###該当のソースコード
for(i=0;i<1000000;i++){
Integer result = (Integer) ibatisのテンプレート(検索文字列)
※resultに対する分岐処理は軽微のため、省略
}
###試したこと
ibatisに検索文字列を渡すの前後でタイムスタンプを取り、戻り値取得までにかかる時間を測定しました。
その結果、この値がループの後半に連れてどんどん伸びているため、ibatisに検索文字列を渡した以降の処理にスループット下降の原因があるかと思われます。
また、DBサーバ上で同様のselect文を100万行記載したSQLファイルを用意し、これを実行したところ、今回の事象は発生せず、遥かに早い時間で完了したため、DB側に問題は無いかと思われます。
###補足情報(言語/FW/ツール等のバージョンなど)
最終的にDB上で実行されるselect文の1件1件は非常にシンプルで、1つのテーブルに対し、渡された文字列を条件にselectをかけているだけです。
また、処理の流れの概要は以下の通りです。
①ibatisに検索文字列を渡す
②DBサーバにselectのクエリを投げる
③DBサーバからアプリサーバへ、検索結果を返す
④次の検索文字列で、①に戻る
※上記①~④を繰り返すに連れ、1回のループにかかる時間が徐々に伸びていきました。
数百万回も繰り返すと、全て終えるまでに数時間を要します。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2016/12/26 01:22