postgresql authentication failed

本文详细解析了部署新机器时遇到的PostgreSQL连接错误'Peer authentication failed for user',并通过创建用户、设置密码、修改配置文件等步骤解决此问题。同时,文章深入探讨了数据库权限分配的过程,包括如何将数据库权限赋予特定用户,以实现有效操作数据库的目标。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

  233人阅读  评论(0)  收藏  举报
  分类:
 


部署完的新机器报错

[ruby]  view plain  copy
  1. App 12595 stderr: PG::ConnectionBad (FATAL:  Peer authentication failed for user "dbuser"  
  2. App 12595 stderr: ):  

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

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

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

[ruby]  view plain  copy
  1. sudo -u postgres createuser --superuser dbuser  

(2)创建数据库uppers_staging,并指定其所有者为dbuser

[ruby]  view plain  copy
  1. sudo -u postgres createdb -O dbuser uppers_staging  

(3)给dbuser设置登录密码,之前没设置的时候报这个错psql: fe_sendauth: no password supplied,设置之后就不报错了

[ruby]  view plain  copy
  1. # sudo -u postgres psql  
  2. psql (9.4.4)  
  3. Type "help" for help.  
  4.   
  5. postgres=# \password dbuser  
  6. Enter new password:   
  7. Enter it again:   
  8. postgres=# \q  

(4)登录查看下数据库

[ruby]  view plain  copy
  1. # psql -U dbuser -d uppers_staging -h 127.0.0.1   
  2. Password for user dbuser:   
  3. psql (9.4.4)  
  4. SSL connection (protocol: TLSv1.2, cipher: ECDHE-RSA-AES256-GCM-SHA384, bits: 256, compression: off)  
  5. Type "help" for help.  
  6.   
  7. uppers_staging=> \l  
  8.                                       List of databases  
  9.         Name        |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges     
  10. --------------------+----------+----------+-------------+-------------+-----------------------  
  11.  postgres           | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |   
  12.  template0          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +  
  13.                     |          |          |             |             | postgres=CTc/postgres  
  14.  template1          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +  
  15.                     |          |          |             |             | postgres=CTc/postgres  
  16.  uppers_development | root     | UTF8     | en_US.UTF-8 | en_US.UTF-8 |   
  17.  uppers_staging     | dbuser   | UTF8     | en_US.UTF-8 | en_US.UTF-8 |   
  18. (5 rows)  

dbuser的权限

[ruby]  view plain  copy
  1. uppers_staging=> \du  
  2.                              List of roles  
  3.  Role name |                   Attributes                   | Member of   
  4. -----------+------------------------------------------------+-----------  
  5.  dbuser    |                                                | {}  
  6.  postgres  | Superuser, Create role, Create DB, Replication | {}  
  7.  root      | Superuser, Create role, Create DB              | {}  

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

[ruby]  view plain  copy
  1. GRANT ALL PRIVILEGES ON DATABASE uppers_staging to dbuser;  

这时候再看一下数据库的权限就变了

[ruby]  view plain  copy
  1. uppers_staging=> \l  
  2.                                       List of databases  
  3.         Name        |  Owner   | Encoding |   Collate   |    Ctype    |   Access privileges     
  4. --------------------+----------+----------+-------------+-------------+-----------------------  
  5.  postgres           | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 |   
  6.  template0          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +  
  7.                     |          |          |             |             | postgres=CTc/postgres  
  8.  template1          | postgres | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =c/postgres          +  
  9.                     |          |          |             |             | postgres=CTc/postgres  
  10.  uppers_development | root     | UTF8     | en_US.UTF-8 | en_US.UTF-8 |   
  11.  uppers_staging     | dbuser   | UTF8     | en_US.UTF-8 | en_US.UTF-8 | =Tc/dbuser           +  
  12.                     |          |          |             |             | dbuser=CTc/dbuser  
  13. (5 rows)  

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


常见的操作命令如下

[ruby]  view plain  copy
  1. \h:查看SQL命令的解释,比如\h select。  
  2. \?:查看psql命令列表。  
  3. \l:列出所有数据库。  
  4. \c [database_name]:连接其他数据库。  
  5. \d:列出当前数据库的所有表格。  
  6. \d [table_name]:列出某一张表格的结构。  
  7. \du:列出所有用户。  
  8. \e:打开文本编辑器。  
  9. \conninfo:列出当前数据库和连接的信息。  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值