Servletで画像データベースを構築しました。
画像データベースといいましても、画像そのものはファイルとして任意のディレクトリに保存し、その画像名や画像情報などをデータベースで管理しています。
それを管理しているときに、DBへの接続エラーが発生しているようなのです。
曖昧な言い方ですいませんが、頻繁に発生するわけではないので(ここ1年で2度)何がどうなっているのかよく分からないのです。
状況は、管理しているとき(データベースへは書き込みと読み込みが連続して行われます。)にのみ問題が発生しています。
ブラウザーの画面でDBから取り出した値は全てnullで表示されています。
ブラウザーの画面が表示されていますので、Tomcatが落ちていることはありません。
シェルからPostgresを操作してみましたが問題なく動作しています。
TomcatからJDBC経由でPostgresに接続が出来ていないのだろうと思うのですが、
どう言った原因でこう言うことになるのでしょうか?また、回避方法はあるのでしょうか?
よろしくお願いします。
TurboLinux8 server
Postgres7.2.4
Tomcat4.1.30
TomcatとPostgresへはデータソースは使っていません。
No.4ベストアンサー
- 回答日時:
OutOfMemoryError についてフォロー。
もしOutOfMemoryError がでている場合、可能であればヒープサイズを増やしましょう。 -Xmx512m とかいうオプションが起動スクリプトにあるかと思います。この512の部分がヒープサイズ(Javaの作業領域みたいなの)になります。ちょっとやそっと増やしてもおっつかないくらいであればアプリケーションの処理内容を見直す必要があるかもしれません。
画像処理というのはヒープをたんまりつかいますから。
あまりにも大きな画像は扱わないようにするとか、そもそもその処理をしないようにするとか。
そのようです。
JDBCのメモリを先に喰っていたようで、まず接続が出来なくなっていたようです。その段階で、こちらに通知がくるようにしていたので、なせDBがとなってしまっていました。
どうも、ありがとうございました。
No.5
- 回答日時:
コネクションの制限はどうなっていますでしょうか?
一度DBサーバーのコネクション制限数を上げて見て様子を見てはいかがでしょうか?
コードが無いのでなんともいえませんが、ひとつの処理中に大量のコネクションを張っていませんか?
もしくは、開放を忘れていませんか?
OhMabuさんがテストする際にはどういうテストをなさっているのでしょうか?
動作確認だけでなく長時間の負荷テスト(同時接続)などを行って実働状況に近づけてみましたか?
たまに起きるということは処理集中時のコネクションの枯渇による影響だと思われます。
No.3
- 回答日時:
画像処理を加えた後に発生しているかも、とのことですからもしかするとTomcat側のヒープ領域が足りなくなっているのかもしれませんね。
まずはログを確認しましょう。ログに OutOfMemoryError など記録されていませんか?
これが発生しては正常な動作は期待できません。
ヒープ領域の使用状況を確認するには -verbose:gc オプションをつけます。するとガベージコレクションが発生するたびに空き領域などが標準出力に記録されます。
侍などを使えば使用状況の遷移をグラフ化して確認することができます。
参考URL:http://yusuke.homeip.net/samurai/
No.2
- 回答日時:
正常に動作しないとき、まずDBへの接続があるかどうか確認しましょう。
netstat -an で接続状況を確認できます。デフォルトのままならば5432番への接続が確立(ESTABLISHED)しているいことが確認できるでしょう。
↓こんなかんじで
--
tcp4 0 0 127.0.0.1.51080 127.0.0.1.5432 ESTABLISHED
--
接続がなければTomcat側のデータソースの設定などを確認してください。
接続しているのに動作がおかしいということならばなんらかの予期せぬ例外が発生しているかのうせいがあります。不正なSQLを発行して例外が発生して適切に値を取得できていないのではないでしょうか。
ログを確認して、それらしき形跡がなければ例外を握りつぶしている可能性があります。
try{
//DBへの接続、SQL発行など
}catch(SQLException(またはException) sqle){}
といったコーディングはありませんか?
この場合なんらかの問題が発生しても確認できませんので適切にスタックトレースを表示するなりフォローの処理を加えるなりしましょう。
この回答への補足
結果的にDBへの接続が出来なくなっているようです。
ただ、1年ほど動かしていて2度この状況になりましたが、私の方(私の操作中)では、正常に動作しており、再現性がなくて困っています。
トンチンカンなことかもしれませんが、postgresのプロセスがなんらかの原因で立ったままになり、メモリを圧迫しているのかな?とかも疑っています。
デバック中はプロセスビューワーなるものを立ち上げながら、各プロセスを監視しながら行ったりもしているのですが、どうも原因がつかめないんです。
一つ気になっているのは、最初は画像のサイズ合わせを各クライアント側で行っていたのですが、途中からImageIOを使用して、サーバー側で行うようにしました。どうも、それ以降、問題が発生しているように思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP htmlspecialcharsが機能していないです。 バグですか? 1 2022/04/05 01:22
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- WordPress(ワードプレス) ワードプレスの管理画面でユーザー名が違うと出るのですがどこで設定したユーザー名を打てばいいのでしょう 1 2022/03/31 19:36
- MySQL PHP 画像のアップロード Qiita 2 2022/11/28 04:44
- 電子マネー・電子決済 QUICPayの登録ができない。 4 2023/06/10 10:57
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- その他(IT・Webサービス) PCを立ち上げ時いつも同じ画像が出ます(トラブル発生、終了) 2 2022/04/23 12:46
- Excel(エクセル) エクセル VBA For Next 繰り返しの書き方を教えてください 6 2022/09/01 14:11
- モニター・ディスプレイ 長文です。デスクトップPCのHDMI入力機能について 4 2022/09/20 17:58
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・2024年に成し遂げたこと
- ・3分あったら何をしますか?
- ・何歳が一番楽しかった?
- ・治せない「クセ」を教えてください
- ・【大喜利】看板の文字を埋めてください
- ・【大喜利】【投稿~12/17】 ありそうだけど絶対に無いことわざ
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・【穴埋めお題】恐竜の新説
- ・我がまちの「給食」自慢を聞かせてっ!
- ・冬の健康法を教えて!
- ・一番好きな「クリスマスソング」は?
- ・集合写真、どこに映る?
- ・自分の通っていた小学校のあるある
- ・フォントについて教えてください!
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・10代と話して驚いたこと
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
データベース接続/切断の基本的...
-
OracleInProcServer.XOraSessio...
-
c#のTLS1.2での通信について
-
ORACLE のバージョンア...
-
VB6.0のコードによるMySQLへの接続
-
System.Net.Sockets.SocketExce...
-
ctfmon.exe。スタック ベースの...
-
TeraTermマクロの”Link...
-
Windowsが起動しなくなってしま...
-
web.configとは?(初心者です)
-
GridviewとDataGridviewの違い
-
砂時計 点滅がなおりません・・
-
Windowsサーバー、PHPでアクセ...
-
●スタンバイ時に任意のアプリを...
-
権限昇格の確認を出さないプロ...
-
スマートフォンでSQL Serverと...
-
有効なwin32アプリケーションで...
-
IUSR でCreateObject("Excel.Ap...
-
タスクバーのボタンがオレンジ...
-
タイマーマクロの二重起動防止...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ASP.NETでSQL-SERVERへの接続方法
-
指定したExcelをSQLテーブルに...
-
c#のTLS1.2での通信について
-
データベース接続/切断の基本的...
-
DB接続エラー
-
System.Net.Sockets.SocketExce...
-
OracleInProcServer.XOraSessio...
-
ConnectNamedPipeの接続待ち
-
ローカル側のC#から、リモート...
-
Android端末から外部DB(MYSQL...
-
VB6.0のコードによるMySQLへの接続
-
アップロード出来るサイトと出...
-
FFFTPでファイル一覧を取得でき...
-
javascriptでSQLite接続
-
●Excel VBAからSQLServerのデー...
-
クライアントとサーバーの接続...
-
JAVAでderbyに接続できない
-
ASP.NETのパフォーマンスと接続...
-
2つの異なるサーバーのDBを扱う
-
【Win7・64・C#】マイコンUSB通...
おすすめ情報