微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PostgreSQL新手上路PG::ConnectionBad (FATAL: Peer authentication failed


部署完的新机器报错

App 12595 stderr: PG::ConnectionBad (FATAL:  Peer authentication Failed for user "dbuser"
App 12595 stderr: ):

上网查了一下,很多帖子上都说要修改/etc/postgresql/9.4/main/pg_hba.conf 这个文件配置,然而并没有什么用

回忆一下整个数据库的搭建过程

(1)创建数据库用户dbuser,并指定为超级用户

sudo -u postgres createuser --superuser dbuser

(2)创建数据库uppers_staging,并指定其所有者为dbuser
sudo -u postgres createdb -O dbuser uppers_staging

(3)给dbuser设置登录密码,之前没设置的时候报这个错psql: fe_sendauth: no password supplied,设置之后就不报错了
# sudo -u postgres psql
psql (9.4.4)
Type "help" for help.

postgres=# \password dbuser
Enter new password: 
Enter it again: 
postgres=# \q

(4)登录查看下数据库

# psql -U dbuser -d uppers_staging -h 127.0.0.1 
Password for user dbuser: 
psql (9.4.4)
SSL connection (protocol: TLSv1.2,cipher: ECDHE-RSA-AES256-GCM-SHA384,bits: 256,compression: off)
Type "help" for help.

uppers_staging=> \l
                                      List of databases
        Name        |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges   
--------------------+----------+----------+-------------+-------------+-----------------------
 postgres           | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
                    |          |          |             |             | postgres=CTc/postgres
 template1          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
                    |          |          |             |             | postgres=CTc/postgres
 uppers_development | root     | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 uppers_staging     | dbuser   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
(5 rows)

dbuser的权限
uppers_staging=> \du
                             List of roles
 Role name |                   Attributes                   | Member of 
-----------+------------------------------------------------+-----------
 dbuser    |                                                | {}
 postgres  | Superuser,Create role,Create DB,Replication | {}
 root      | Superuser,Create DB              | {}

接下来要将数据库uppers_staging 的所有权限都赋给dbuser,否则dbuser只有登录控制台的权限,没有操作数据库的权限
 GRANT ALL PRIVILEGES ON DATABASE uppers_staging to dbuser;

这时候再看一下数据库的权限就变了
uppers_staging=> \l
                                      List of databases
        Name        |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges   
--------------------+----------+----------+-------------+-------------+-----------------------
 postgres           | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 template0          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
                    |          |          |             |             | postgres=CTc/postgres
 template1          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +
                    |          |          |             |             | postgres=CTc/postgres
 uppers_development | root     | UTF8     | en_US.UTF-8 | en_US.UTF-8 | 
 uppers_staging     | dbuser   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =Tc/dbuser           +
                    |          |          |             |             | dbuser=CTc/dbuser
(5 rows)

其实报错的原因就是没有授权


常见的操作命令如下

\h:查看sql命令的解释,比如\h select。
\?:查看psql命令列表。
\l:列出所有数据库。
\c [database_name]:连接其他数据库。
\d:列出当前数据库的所有表格。
\d [table_name]:列出某一张表格的结构。
\du:列出所有用户。
\e:打开文本编辑器。
\conninfo:列出当前数据库和连接的信息。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐