[解決済み] SQLエラーです。0, SQLState: 08006
質問
私は、Hibernate接続を持つWebアプリケーションを持っています。時々、ログに以下のような例外が表示されることがあります。
Caused by: **org.postgresql.util.PSQLException: An I/O error occured while sending to the backend.**
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:283)
at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:479)
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:353)
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeQuery(AbstractJdbc2Statement.java:252)
at org.apache.commons.dbcp.DelegatingStatement.executeQuery(DelegatingStatement.java:208)
at org.apache.commons.dbcp.DelegatingStatement.executeQuery(DelegatingStatement.java:208)
at org.geotools.jdbc.JDBCFeatureReader.<init>(JDBCFeatureReader.java:150)
at org.geotools.jdbc.JDBCFeatureSource.getReaderInternal(JDBCFeatureSource.java:567)
... 101 more
**Caused by: java.io.EOFException**
at org.postgresql.core.PGStream.ReceiveChar(PGStream.java:261)
at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1620)
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:257)
Caused by: org.postgresql.util.PSQLException: **An I/O error occured while sending to the backend.**
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:283)
at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:479)
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:353)
at org.postgresql.jdbc2.AbstractJdbc2Statement.executeQuery(AbstractJdbc2Statement.java:252)
at org.apache.commons.dbcp.DelegatingStatement.executeQuery(DelegatingStatement.java:208)
at org.apache.commons.dbcp.DelegatingStatement.executeQuery(DelegatingStatement.java:208)
at org.geotools.jdbc.JDBCFeatureReader.<init>(JDBCFeatureReader.java:150)
at org.geotools.jdbc.JDBCFeatureSource.getReaderInternal(JDBCFeatureSource.java:567)
... 101 more
**Caused by: java.net.SocketException: Connection reset**
at java.net.SocketInputStream.read(Unknown Source)
at java.net.SocketInputStream.read(Unknown Source)
at org.postgresql.core.VisibleBufferedInputStream.readMore(VisibleBufferedInputStream.java:135)
at org.postgresql.core.VisibleBufferedInputStream.ensureBytes(VisibleBufferedInputStream.java:104)
at org.postgresql.core.VisibleBufferedInputStream.read(VisibleBufferedInputStream.java:73)
at org.postgresql.core.PGStream.ReceiveChar(PGStream.java:259)
at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1620)
at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:257)
何が問題なのでしょうか?ハイバーネートの設定ファイルで何か変更する必要があるのか、またはコードに問題があるのか。あなたの提案を教えてください。
私のハイバーネートの設定は以下の通りです。
<property name="hibernate.c3p0.min_size">5</property>
<property name="hibernate.c3p0.max_size">20</property>
<property name="hibernate.c3p0.timeout">5000</property>
<property name="hibernate.c3p0.max_statements">0</property>
<property name="hibernate.c3p0.idle_test_period">3000</property>
以下の私のpostgreSQLログをご覧ください。
2014-02-19 07:22:35 IST LOG: server process (PID 74813) was terminated by signal 6: Aborted
2014-02-19 07:22:35 IST LOG: terminating any other active server processes
2014-02-19 07:22:35 IST WARNING: terminating connection because of crash of another server process
2014-02-19 07:22:35 IST DETAIL: The postmaster has commanded this server process to roll back the current transaction and exit, because another server process exited abnormally and possibly corrupted shared memory.
2014-02-19 07:22:35 IST HINT: In a moment you should be able to reconnect to the database and repeat your command.
2014-02-19 07:22:35 IST WARNING: terminating connection because of crash of another server process
2014-02-19 07:22:35 IST DETAIL: The postmaster has commanded this server process to roll back the current transaction and exit, because another server process exited abnormally and possibly corrupted shared memory.
2014-02-19 07:22:35 IST HINT: In a moment you should be able to reconnect to the database and repeat your command.
2014-02-19 07:22:35 IST LOG: all server processes terminated; reinitializing
2014-02-19 07:22:35 IST LOG: database system was interrupted; last known up at 2014-02-19 07:22:29 IST
2014-02-19 07:22:35 IST LOG: database system was not properly shut down; automatic recovery in progress
2014-02-19 07:22:35 IST LOG: record with zero length at 0/16D89BB0
2014-02-19 07:22:35 IST LOG: redo is not required
2014-02-19 07:22:35 IST LOG: autovacuum launcher started
2014-02-19 07:22:35 IST LOG: database system is ready to accept connections
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
2014-02-19 11:17:59 IST LOG: unexpected EOF on client connection
私のサーバーOSは-。 レッドハット・エンタープライズ・リナックス 6 64ビット PostgreSQLのバージョン - postgreSQL 9.1
解決方法は?
なるほど、それは興味深いですね。
<ブロッククオート2014-02-19 07:22:35 IST LOG: サーバープロセス (PID 74813) はシグナル 6 によって終了しました: Aborted
これは、PostgreSQLサーバーのバックエンドがクラッシュしていることを示しています。具体的には、シグナル 6 (SIGABRT) は次のように発生します。 アサーションの失敗 これは、何かが間違っていて、データが破壊される危険を冒さなければ継続できないため、コードが意図的にクラッシュしていることを意味します。
もし、あなたが使用している PostgreSQL のバージョン(あなたが言及していないもの)の最新のパッチリリースを実行していないなら、今すぐアップデートしてください。
(残りは本当はもっと質問なのですが、SOのフォーマットではコメントがあまりにも制限されることがあります)。
を有効にすることをお勧めします。
log_statement = all
を付けて
log_line_prefix
には、少なくともバックエンドの pid とトランザクション ID が含まれています。その後、PostgreSQLをリロードして設定を有効にしてください。次に問題が発生した時、クエリログを見て、クラッシュしたプロセスがクラッシュした時に何を実行していたかを確認してください。コンソールで同じ文を対話的に実行すると、クラッシュが起こるかどうかを確認してください。
また、コアダンプファイルを有効にし、お使いのPostgreSQLのバージョンに対応したdebuginfoパッケージをダウンロードすることをお勧めします。これにより、クラッシュしたときのサーバの状態を含むファイルにデバッガをアタッチすることができ、何が問題だったのかが分かると思います。コアダンプを有効にする方法はOS/Distroに依存し、OSとバージョンについて言及されていないので、より具体的な説明はできません。
関連
-
[解決済み】HTTPステータス 405 - リクエストメソッド「POST」はサポートされていません (Spring MVC)
-
[解決済み】imageio.IIOException: 入力ファイルが読み込めない
-
[解決済み】Javaの".class期待値"
-
[解決済み】StringUtils.isBlank() vs String.isEmpty()
-
[解決済み] 解決済み】Javaが「型をインスタンス化できない」というエラーを返す [重複] [重複]
-
[解決済み】Eclipseがエラーメッセージ "Java was started but returned exit code = 1" を返す
-
[解決済み】デフォルトのキーストアファイルが存在しない?
-
[解決済み】文字列中の � を置換する方法
-
[解決済み】スレッド "main "での例外 java.util.NoSuchElementException
-
[解決済み】Eclipseで「パッケージエクスプローラー」ビューが見つからない
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み] java.sql.SQLException: ユーザー 'root'@'localhost' (using password: YES) のためのアクセスが拒否されました。
-
[解決済み] hibernateでResultSetを抽出できない。
-
[解決済み】「'void' type not allowed here」エラーの原因とは?
-
[解決済み】不正な反射的アクセスとは?
-
[解決済み】Javaクラスの "型に解決できない"
-
[解決済み] 二項演算子「&」のオペランド型がおかしい java
-
[解決済み】Mockitoでモックからチェックされた例外を投げる
-
[解決済み】メソッド本体がない、またはJavaで抽象的な宣言をする
-
[解決済み] [Solved] java.lang.NoClassDefFoundError: クラスXXXを初期化できませんでした。
-
[解決済み】CreateProcess error=2, The system cannot find file specified.