質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

サーバ

サーバは、 クライアントサーバモデルにおいてクライアントからの要求に対し 何らかのサービスを提供するプログラムを指す言葉です。 また、サーバーソフトウェアを稼動させているコンピュータ機器そのもののことも、 サーバーと呼ぶ場合もあります。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

973閲覧

EC2インスタンスでたてたAPサーバとDBサーバの連携にJDBCドライバを使用しているが、コネクションエラーが発生する

greeash

総合スコア30

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

PostgreSQL

PostgreSQLはオープンソースのオブジェクトリレーショナルデータベース管理システムです。 Oracle Databaseで使われるPL/SQLを参考に実装されたビルトイン言語で、Windows、 Mac、Linux、UNIX、MSなどいくつものプラットフォームに対応しています。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

サーバ

サーバは、 クライアントサーバモデルにおいてクライアントからの要求に対し 何らかのサービスを提供するプログラムを指す言葉です。 また、サーバーソフトウェアを稼動させているコンピュータ機器そのもののことも、 サーバーと呼ぶ場合もあります。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2018/12/22 03:22

編集2018/12/24 01:16

前提・実現したいこと

webシステムを作成中です。
EC2インスタンスで、APサーバとDBサーバを作成しました。(RDSは使いません)
APサーバにはtomcatとJdbcドライバを、DBサーバにはPostgreSQLをインストールしています。
動かすと、DBにアクセスするところでエラーが発生します。
※ ローカルではうまく動いていました。

同じExceptionが発生している方の記事を探したのですが、探し方が悪いのか、ローカル環境で実施した際の事象が多く
解決策をみつけられませんでした。

以下の試したことのほかに確認するべき点をご存知の方がいらっしゃいましたら、教えていただきたいです。

試したこと・環境

DBサーバ側のセキュリティポート5432を設定しました。
接続先のIPアドレスを、DBサーバのIPv4 パブリック IPと、プライベートIPどちらも試しました。(ここは、どちらが正解なのでしょうか。。)

OS:RedHat7(どちらも)
言語:Java
FW:SpringFramework
DB:PostgreSQL

発生している問題・エラーメッセージ

org.springframework.jdbc.CannotGetJdbcConnectionException: Failed to obtain JDBC Connection; nested exception is org.postgresql.util.PSQLException: Connection to xxx.xxx.xxx.xxx:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections.

該当のソースコード

application-config.xmlの記述を抜粋します。

xml

1<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 2<property name="driverClassName" value="org.postgresql.Driver" /> 3<property name="url" value="jdbc:postgresql://xxx.xxx.xxx.xxx:5432/▲▲db" /> 4<property name="username" value="▲▲▲▲▲▲" /> 5<property name="password" value="▲▲▲▲▲▲" /> 6</bean>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2018/12/24 04:41

認証設定(ポスグレ側)がその接続方法を許可してないってでてるんじゃね
greeash

2018/12/24 05:41

ポスグレ側の設定方法を色んな記事を参照しなおしてみたところ、postgresql.confの設定が漏れていたことと、pg_hba.confの設定方法が間違っていました。ありがとうございます。
guest

回答1

0

自己解決

設定漏れが原因でした。以下の2点を修正したところ、無事に接続することができました。

1.postgresql.confを以下のように修正する

#listen_addresses = 'localhost' ↓ listen_addresses = '*'

2.pg_hba.confに以下の情報を追加する

host all all 接続許可するIPアドレス/32 trust

投稿2018/12/24 05:43

greeash

総合スコア30

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問