1. 程式人生 > 資料庫 >解決postgresql無法遠端訪問的情況

解決postgresql無法遠端訪問的情況

今天剛入手這個資料庫玩玩,發現無法通過IP去訪問資料庫,後面查詢原因為,該資料庫預設只能通過本地連線,也就是迴環地址(127.0.0.1)

解決方案:

1.修改安裝目錄下的data\pg_hba.conf,在配置檔案最後有IPV4和IPV6的配置,新增一行(這裡我用的IPV4,開放所有IP)

host all all 0.0.0.0/0 md5

說明:

該配置為允許所有IP訪問,下面有對應的一些配置示例提供參考

32 -> 192.168.1.1/32 表示必須是來自這個IP地址的訪問才合法;

24 -> 192.168.1.0/24 表示只要來自192.168.1.0 ~ 192.168.1.255的都合法;

16 -> 192.168.0.0/16 表示只要來自192.168.0.0 ~ 192.168.255.255的都合法;

8 -> 192.0.0.0/16 表示只要來自192.0.0.0 ~ 192.255.255.255的都合法;

0 -> 0.0.0.0/0 表示全部IP地址都合法,合法的IP地址即可;

解決postgresql無法遠端訪問的情況

2.儲存即可(我用的版本為最新版本9.6.0),通過客戶端工具直接連線測試即可.

PS:

另外有看到說要修改兩個配置檔案的,一個是上面的配置檔案,還有個是postgresql.conf,將配置檔案的listen_addresses修改為監聽所有,也就是listen_addresses = '*',不過我發現我的預設就是這個,也就沒修改了,這裡也可以進行埠號修改,但是改了之後必須重啟才生效.

解決postgresql無法遠端訪問的情況

補充:Postgresql客戶端不能遠端連線資料庫伺服器 org.postgresql.util.PSQLException:

Postgresql安裝完成之後,預設情況下是不允許遠端客戶端直接連線的,並且預設的監聽配置檔案裡邊,監聽的伺服器地址是127.0.0.1即:localhost

報如下錯誤

org.postgresql.util.PSQLException: FATAL: no pg_hba.conf entry for host "<host_ip>",user "fkong",database "fkong",SSL off

因此我們需要修改兩個地方,pg_hba.conf postgresql.conf

odoo@odooV01:/etc/postgresql/9.6/main$ pwd
/etc/postgresql/9.6/main
odoo@odooV01:/etc/postgresql/9.6/main$ 
odoo@odooV01:/etc/postgresql/9.6/main$ ls
environment pg_ctl.conf pg_hba.conf pg_ident.conf postgresql.conf start.conf
odoo@odooV01:/etc/postgresql/9.6/main$ 

(1)在PostgreSQL資料庫的安裝目錄下找到pg_hba.conf,vi開啟,找到

“# IPv4 local connections:”

在其下加上請求連線的機器IP

預設配置:

host all all 127.0.0.1/32 md5

32是子網掩碼的網段;md5是密碼驗證方法,可以改為trust

即:

host all all 你的客戶端IP/32 trust

或者允許所有不同網段機器訪問:

host all all 0.0.0.0/0 trust

(2) 同樣在該目錄下,vi 開啟postgresql.conf檔案 找到 listen_addresses = 'localhost' 這一行,

修改為:

listen_addresses = '*'

(3) 重啟postgresql服務,和其他服務一樣還是用systemd進行管理:

切換到:postgres使用者 執行重啟服務操作:

systemctl stop postgresql-9.6 #停止服務
systemctl start postgresql-9.6 #啟動服務

其他命令:

systemctl restart postgresql-9.6 #重啟服務
systemctl enable postgresql-9.6 #自動啟動
service postgresql-10 start
或者(注意不同的版本指定不同版本號)
service postgresql-9.6 start

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援我們。如有錯誤或未考慮完全的地方,望不吝賜教。