【发布时间】:2013-01-23 00:21:59
【问题描述】:
我对 PostreSQL 还是很陌生。我整个上午都在试图让用户登录正常工作,现在我感到非常沮丧!
所以,我有一个 PostGIS 数据库,版本 9.2,作为 OpenGeo 软件套件的一部分。我可以使用 postgres 用户访问数据库,但希望创建一个可以访问数据库的组角色和用户,以便它可以在该数据库中创建表和更新/选择/删除等。
我可以创建一个有效的用户,并且可以使用该用户登录。我可以创建一个组角色并为该角色分配权限。然后我可以将用户添加到组角色,然后就不能再登录了!
甚至当我将用户 postgres 添加到组时,该用户无法登录。我删除了该组,但仍然无法登录。
现在,我经常使用 pg_hba.conf。我现在可以使用 postgres 登录,但前提是启用了“信任”,并且我无法使用任何软件(例如 PGAdminIII)登录。
如果能获得一些关于出了什么问题的建议,并再次启用经过身份验证的登录,那就太好了。
pg_hba:
Code:
# Database administrative login by Unix domain socket
local all postgres trust
local all gisadmin trust
# TYPE DATABASE USER ADDRESS METHOD
local all opengeo md5
local all opengeo md5
# "local" is for Unix domain socket connections only
local all all md5
# IPv4 local connections:
host all all 127.0.0.1/32 md5
host all gisadmin localhost trust
# IPv6 local connections:
host all all ::1/128 md5
# Allow replication connections from localhost, by a user with the
# replication privilege.
#local replication postgres peer
#host replication postgres 127.0.0.1/32 md5
#host replication postgres ::1/128 md5
最后一点,我希望能够通过 SSH 隧道登录。我最初可以对“postgres”用户执行此操作,但现在我从组中添加和删除了该用户,我不能。
编辑:错误信息...
如果我在 PGAdmin 中使用正确的密码通过 SSH 隧道登录,我会收到错误消息“FATAL: password authentication failed for the user ...”
如果我尝试在没有密码的情况下通过 PGAdmin 中的 SSH 隧道登录,而设置了信任选项,我会收到错误消息:“连接到服务器时出错:fe_sendauth:未提供密码”。
本地登录时第一个错误仍然发生,只是通过SSH和psql,但第二个错误消失了,我可以登录了。
\du+ 的输出:
\dg+ 的输出
【问题讨论】:
-
请给出错误信息并说明您是尝试本地连接还是远程连接
-
我添加了错误消息。如果不存在“信任”,则本地和远程的“密码验证失败”。如果信任是,它仍然会远程失败。最终我想远程连接。我可以在本地连接,但是那里的密码验证也被破坏了......
-
你能显示你在安装过程中运行的实际命令吗?还有
psql中\du+和\dg+的输出? -
添加了 du 和 dg 的输出。我运行的实际命令变化很大...有些是通过 PGAdmin 完成的。
标签: postgresql