Когда для подключения к серверу я использую URL jdbc:postgresql:dbname , или jdbc:postgresql://localhost/dbname подключение происходит нормально , но если я буду в виде хоста использовать свой адрес , например 192.168.1.87 , то подключение даже на локальном хосте даёт ошибку.
Может быть , что это от того , что у меня порт закрыт?
Подскажите , пожалуйста , в чём моя проблема.Заранее благодарен.
tcp 5432 естественно должен быть открыт -- но проблемы скорей свего в pg_hba.conf
самое интересное, что ошибку нужно было продемонстрировать.
>Подскажите , пожалуйста , в чём моя проблема.
>Заранее благодарен.Прболема скорее всего в настройках безопасности java. Покажите ошибку.
org.postgresql.util.PSQLException: Connection refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections.
Exception: java.net.ConnectException: Connection refused
Stack Trace:
java.net.ConnectException: Connection refused
at java.net.PlainSocketImpl.socketConnect(Native Method)
at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
at java.net.Socket.connect(Socket.java:519)
at java.net.Socket.connect(Socket.java:469)
at java.net.Socket.<init>(Socket.java:366)
at java.net.Socket.<init>(Socket.java:179)
at org.postgresql.core.PGStream.<init>(PGStream.java:59)
at org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:77)
at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:66)
at org.postgresql.jdbc2.AbstractJdbc2Connection.<init>(AbstractJdbc2Connection.java:125)
at org.postgresql.jdbc3.AbstractJdbc3Connection.<init>(AbstractJdbc3Connection.java:30)
at org.postgresql.jdbc3.Jdbc3Connection.<init>(Jdbc3Connection.java:24)
at org.postgresql.Driver.makeConnection(Driver.java:382)
at org.postgresql.Driver.connect(Driver.java:260)
at java.sql.DriverManager.getConnection(DriverManager.java:582)
at java.sql.DriverManager.getConnection(DriverManager.java:185)
at DB.connect(DB.java:65)
at Avandsis.<init>(Avandsis.java:14)
at Avandsis.main(Avandsis.java:23)
at __SHELL0.run(__SHELL0.java:6)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at bluej.runtime.ExecServer$3.run(ExecServer.java:855)
End of Stack Traceat org.postgresql.core.v3.ConnectionFactoryImpl.openConnectionImpl(ConnectionFactoryImpl.java:122)
at org.postgresql.core.ConnectionFactory.openConnection(ConnectionFactory.java:66)
at org.postgresql.jdbc2.AbstractJdbc2Connection.<init>(AbstractJdbc2Connection.java:125)
at org.postgresql.jdbc3.AbstractJdbc3Connection.<init>(AbstractJdbc3Connection.java:30)
at org.postgresql.jdbc3.Jdbc3Connection.<init>(Jdbc3Connection.java:24)
at org.postgresql.Driver.makeConnection(Driver.java:382)
at org.postgresql.Driver.connect(Driver.java:260)
at java.sql.DriverManager.getConnection(DriverManager.java:582)
at java.sql.DriverManager.getConnection(DriverManager.java:185)
at DB.connect(DB.java:65)
at Avandsis.<init>(Avandsis.java:14)
at Avandsis.main(Avandsis.java:23)
at __SHELL0.run(__SHELL0.java:6)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at bluej.runtime.ExecServer$3.run(ExecServer.java:855)
порт закрыт похоже
проверяем так "telnet 192.168.1.87 5432"
Да , похоже закрыт.$ telnet 192.168.1.87 5432
Trying 192.168.1.87...
telnet: Unable to connect to remote host: No route to hostА как его открыть?
iptable?
>А как его открыть?
>iptable?ага
iptables -A INPUT -m tcp -p tcp -dport 5432 -s <наша сетка 192.168.0.0/24 например> -j ACCEPT
>Да , похоже закрыт.
>
>$ telnet 192.168.1.87 5432
>Trying 192.168.1.87...
>telnet: Unable to connect to remote host: No route to host
>
>А как его открыть?
>iptable?
>
>
chitat' i dumat' pro optsiu listen_addresses v postgresql.conf
http://www.postgresql.org/docs/8.2/static/runtime-config-con...