本投稿では前回Windows Server2016にインストールしたPostgreSQL(Ver12.2)へクライアント端末から接続する方法を紹介します。
接続方法はpgAdmin4およびpsqlコマンドを用いた接続を実施します。
2つの接続方法を実現するための大まかな設定の流れは以下となります。
- Windows Server 2016でのポート開放
- クライアント端末でpgAdmin4のインストール
- クライアント端末で環境変数設定
PostgreSQL用のポート開放
本手順はWindows Server 2016側で実施する。
-[Windows]>[管理ツール]>[セキュリティが強化された Windows ファイアウオール]をクリックする。
data:image/s3,"s3://crabby-images/b962e/b962e1cd4e8371d956ce2ee393a83c2501eee8cc" alt=""
-[受信の規則]>[新しい規則]をクリックする。
data:image/s3,"s3://crabby-images/adbde/adbde48eb6d27aa9ab898388572c9b83b41b0ed3" alt=""
-[ポート]を選択して[次へ]をクリックする。
data:image/s3,"s3://crabby-images/15c97/15c97ee8fcd45bec10000e1fce713c746d0df92a" alt=""
-以下の通り設定する。
TCP と UDP のどちらにこの規則を適用しますか? ⇒ TCP
特定のローカル ポート ⇒ 5432 ※postgresql.confのportを確認する。
data:image/s3,"s3://crabby-images/d344a/d344a780053bc35007494f3ffef4c507feba76a7" alt=""
-[接続を許可する]にチェックがついていることを確認し[次へ]をクリックする。
data:image/s3,"s3://crabby-images/0f4ce/0f4ce63031b5d2be9761b3619ca8de2710134c53" alt=""
-[次へ]をクリックする。 (状況に応じてチェックするしないを決めてください)
data:image/s3,"s3://crabby-images/68b19/68b19f1f095a933df23012faa06c4b5bbe0c8f90" alt=""
-どういった規則なのかわかりやすい名前をつけて[完了]をクリックする。
data:image/s3,"s3://crabby-images/9627d/9627d9213b8fc5bcfe53ffeb9cf419ccc28e8809" alt=""
pgAdmin4のインストール
本手順はクライアント端末(Windows 10)側で実施する。
pgAdmin4のダウンロードサイトから.exeファイルをダウンロードする。
(本投稿では pgadmin4-4.16-x86.exe をダウンロード)
data:image/s3,"s3://crabby-images/1a046/1a046b9145d1f479270afeb507894545724b6245" alt=""
-ダウンロードした pgadmin4-4.16-x86.exe を実行し、[Next >]をクリックする。
data:image/s3,"s3://crabby-images/8fed6/8fed6d75b9c4323e0ea988a4bdb70a705c753db1" alt=""
-[I accept the agreement]を選択し、[Next >]をクリックする。
data:image/s3,"s3://crabby-images/48164/481647c1a5df509be66163d3a23a2c44bf169673" alt=""
-pgAdmin4のインストール場所を指定し、[Next >]をクリックする。
data:image/s3,"s3://crabby-images/b644e/b644eee3be74a13a91e7a600540f8ff9be54c7be" alt=""
-[Next >]をクリックする。
data:image/s3,"s3://crabby-images/e129e/e129efc5dde5024d7480cb0f1e5a9a43c0d42aed" alt=""
-[Install]をクリックする。
data:image/s3,"s3://crabby-images/829d1/829d1b14ef9de6976a08022bf1377db17a25f386" alt=""
-[Finish]をクリックする。
data:image/s3,"s3://crabby-images/0a378/0a378c0571add4e9442ede07ac22a5b52590a971" alt=""
pgAdmin4での接続
pgAdmin4のインストールが完了したのでpgAdmin4で前回構築したデータベースpostgresへ接続してみます。
-セットアップ完了後、pgAdmin4が起動する。
任意のパスワードを入力し、[OK]をクリックする。
data:image/s3,"s3://crabby-images/5102b/5102b0c9b5daad030c1a4087b561c8cdf7ef0732" alt=""
-[Servers]を右クリックし、[Create]>[Server]をクリックする。
data:image/s3,"s3://crabby-images/6a569/6a569be9fe85654fcbc4167f74395f6a3341ca20" alt=""
-[Name]に任意の名前を入力し、[Connection]タブをクリックする。
data:image/s3,"s3://crabby-images/d8abc/d8abc3d83197d03d75fe87d9fd83e9937e6ffb36" alt=""
-以下を入力し、[Save]をクリックする。
Host:postgre ※ホスト名を指定する場合はhostsファイルでの設定を忘れずに
Port:5432
Maintenance database:postgres
Username:postgres
Password:***********
Save password? ☑
data:image/s3,"s3://crabby-images/46b1f/46b1f1c5a934230afe431921044e422c8c32147a" alt=""
データベースpostgresの情報がDashboardに表示されることを確認する。
data:image/s3,"s3://crabby-images/125ab/125abbe4ba57f6b8ca2d4eb217edb235567eb651" alt=""
FATAL: no pg_hba.conf entry for host ~の対処
クライアント端末からPgAdminを介してPostgreSQLデータベースへ接続しようとすると以下エラーに遭遇する。
FATAL: no pg_hba.conf entry for host “IPアドレス”, user “ユーザ名”, database “データベース名”, SSL off
data:image/s3,"s3://crabby-images/d72c8/d72c8282c1ffa62a4aba5419dfca51df29d7882f" alt=""
本エラーはPostgreSQLをインストールしたサーバのpg_hba.conf(dataフォルダ直下にあります)に追記することで解決する。
pg_hba.confの「# IPv4 local connections:」に以下内容を追記する。
host all all XXX.XXX.XXX.XXX(IPアドレス)/32 trust
data:image/s3,"s3://crabby-images/466e7/466e74a95f275484cb8d306fe07f87228e8f0ffb" alt=""
指定するIPアドレス(XXX.XXX.XXX.XXX)はPgAdmin4上で表示された「 FATAL: no pg_hba.conf entry for host “IPアドレス” 」のIPアドレスの部分で良いが、PostgreSQLデータベースをインストールしたサーバ上のログファイルでも確認することができる。
格納場所:C:\Program Files\PostgreSQL\12\data\log
data:image/s3,"s3://crabby-images/94153/941539180af93475382b67cf581bfbe7e0063524" alt=""
data:image/s3,"s3://crabby-images/20273/2027342c8e1ce4a65147822fc5d01dd9c548edb9" alt=""
no pg_hba.conf entry for host の後ろのダブルクォーテーションで囲まれているIPアドレスを指定してあげれば良い。
[サービス]を開き、PostgreSQLを再起動する。
data:image/s3,"s3://crabby-images/b81a3/b81a3e31e2da070f2fb088a3b8c179b90bae4bb6" alt=""
クライアント端末からpsqlコマンドでPostgreSQLへ接続
クライアント端末からpsqlコマンドでPostgreSQLへ接続するにはまずは環境変数を設定します。
本手順はpgAdmin4がインストール済みであることを前提に実施しています。
-[コントロールパネル]> [システムとセキュリティ]> [システム]>[システムの詳細設定]をクリックする。
data:image/s3,"s3://crabby-images/ea285/ea285d55c50c2c2ab4ec30e53ac20934bc473085" alt=""
-[環境変数]をクリックする。
data:image/s3,"s3://crabby-images/69896/698963e687c45584a4e5acadd8e55860b33f87df" alt=""
-[新規]をクリックし、以下を入力し、[OK]をクリックする。
変数名:psql
変数値:C:\Program Files (x86)\pgAdmin 4\v4\runtime
data:image/s3,"s3://crabby-images/2aa03/2aa03b0578e393840c3ffec4926f0b2dfaf18046" alt=""
CMDを開き、PostgreSQLへ接続できるか確認する。
> psql -U postgres -d postgres -h postgre
-Uオプション ユーザ指定
-dオプション データベース指定
-hオプション ホスト名指定
data:image/s3,"s3://crabby-images/046d7/046d7fe33b3be88e7d0acdab353a0b5229a7e38d" alt=""
今回の手順ではクライアント端末からpgAdmin4およびpsqlコマンドでPostgreSQLへ接続することができました。
そこまで難しい手順ではないのですが複数のRDBMSを扱うと「何が必要だっけ?」と思い出せなかったりします。
Oracle、SQL Server、今回のPostgreSQLとRDBMSごとにインストール、接続方法等は違うのでそれぞれのやり方を別の投稿で紹介できたらなと思います。
コメント