无法通过错误消息连接到greenplum:"没有pg_hba.conf条目"

时间:2016-03-01 11:49:57

标签: postgresql greenplum

我使用的是gp 4.3.7.2,我按照手册http://120.52.72.46/gpdb.docs.pivotal.io/c3pr90ntcsf0/gs/43/pdf/GPDB43xGettingStarted.pdf

我可以使用admin用户连接到服务器,但是当我尝试使用其他用户时,我收到错误消息

psql: FATAL:  no pg_hba.conf entry for host "[local]", user "gpuser", database "rdw", SSL off

我已经对stackoverflow做了一些研究。我修改了pg_hba.conf,添加了一个条目

host  all  all 0.0.0.0/0 md5

然后使用gpstop -uSELECT pg_reload_conf();重新加载配置文件,甚至尝试重新启动gp服务器。但我仍然得到同样的错误。

我还尝试了其他条目,比如

host    all             all             127.0.0.1/32            md5

这也没有用。

请告诉我如何解决这个问题。

编辑:

我在单节点模式下重新安装了数据库,并完全遵循之前提到的手册。我为这两个用户创建了两个用户:user1,user2和grant role users。 我执行的是什么: 在命令行中:

$ createuser -P user1
Enter password for new role:
Enter it again:
Shall the new role be a superuser? (y/n) n
Shall the new role be allowed to create databases? (y/n) y
Shall the new role be allowed to create more new roles? (y/n) n

在psql中:

=# CREATE USER user2 WITH PASSWORD 'changeme' CREATEDB NOSUPERUSER;    
=# CREATE ROLE users;
=# GRANT users TO user1, user2;

这是我的整个pg_hba.conf,它位于/data/gp/server/master/gpsne-1/pg_hba.conf。我添加了最后3行。

local    all         hadoop         ident
host     all         hadoop         127.0.0.1/28    trust
host     all         hadoop         10.10.10.32/32       trust
host     all         hadoop         ::1/128       trust
host     all         hadoop         fe80::d6ae:52ff:feb9:87c2/128       trust
local    replication hadoop         ident
host     replication hadoop         samenet       trust
local tutorial +users md5
local tutorial +users 127.0.0.1/28 md5
hostssl tutorial +users samenet md5

但我仍然得到同样的错误。

psql: FATAL:  no pg_hba.conf entry for host "[local]", user "user1", database "tutorial", SSL off

当我安装数据库时,我收到一条警告消息,不确定它是否相关。

20160302:10:44:51:023434 gpinitsystem:bobcat04:hadoop-[WARN]:-Host 127.0.0.1 is assigned as localhost in /etc/hosts
20160302:10:44:51:023434 gpinitsystem:bobcat04:hadoop-[WARN]:-This will cause segment->master communication failures
20160302:10:44:51:023434 gpinitsystem:bobcat04:hadoop-[WARN]:-Remove 127.0.0.1 from local host line in /etc/hosts

2 个答案:

答案 0 :(得分:3)

你在最后一行有一个错误:

local tutorial +users 127.0.0.1/28 md5

不应为本地连接列出IP地址。

您是否在进行更改后运行gpstop -u重新加载? 我怀疑由于线路无效而重新加载失败。

删除该行并再次运行gpstop -u并尝试再次连接。

答案 1 :(得分:0)

psql: FATAL:  no pg_hba.conf entry for host "[local]", user "gpuser", database "rdw", SSL off

这意味着您尝试使用psql从主主机连接到Greenplum,而不指定主机名。如果你只输入:

psql

psql客户端将尝试连接到Greenplum的LOCAL实例。您添加的pg_hba.conf条目用于HOST身份验证,而不是LOCAL。

你可以通过做两件事之一来解决这个问题。

  1. 使用psql并且想要使用pg_hba.conf文件中的HOST条目进行身份验证时,请添加-h选项。这告诉客户端连接到Greenplum并使用主机条目进行身份验证。

    psql -h mdw
    
  2. 您还可以在pg_hba.conf文件的底部添加一个条目,如下所示:

    local all all md5
    

    或者如果你信任当地人

    local all all trust
    
  3. 有关pg_hba.conf文件的更多信息,请访问:http://www.postgresql.org/docs/8.2/static/auth-pg-hba-conf.html