PostgreSQL问题: expected authentication request from server, but received v

28 篇文章 1 订阅
8 篇文章 0 订阅
本文讲述了在Linux虚拟机上,C++程序无法连接PostgreSQL14数据库的问题。问题源于openGauss库路径被加入LD_LIBRARY_PATH,导致程序误用openGauss库而非PostgreSQL库。解决方案是避免将openGauss库路径加入环境变量,或确保执行程序的用户与openGauss安装用户分离,以防止库冲突。
摘要由CSDN通过智能技术生成

(一)现象

某台Linux虚拟机上的C++程序无法连接PostgreSQL14数据库 ⚠️
报错:expected authentication request from server, but received v

并观察到下列现象:

  1. 同台主机同一个程序,改连接本地openGauss3.0.0数据库正常。
  2. 同台主机上的Java程序可以正常连接PostgreSQL14数据库。
  3. 其它虚拟机/实体机的其它程序均可正常连接PostgreSQL14数据库。

(二)分析

其实拖了很久才搞懂的……

经过分析,该虚拟机上安装了openGauss3.0.0服务端。
设置了:export LD_LIBRARY_PATH=$GAUSSHOME/lib:$LD_LIBRARY_PATH
导致C++程序找库的时候没找到PostgreSQL的库,而是错找成了openGauss的库,

(三)解决

  • 不要将openGauss的库目录加入LD_LIBRARY_PATH,但是openGauss服务端就无法启动了。
  • 执行C++程序的用户,和安装openGauss的用户分开,防止互相干扰。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当出现类似于"psql: error: FATAL: Peer authentication failed for user 'postgres'"的错误提示时,这通常表示登录PostgreSQL数据库时认证失败。这个错误通常发生在使用Peer认证方法和相应的身份验证配置不正确的情况下。 Peer认证是一种基于操作系统用户身份验证的方法,它要求登录用户的操作系统用户必须与PostgreSQL的用户一致。换句话说,你需要使用与PostgreSQL用户相同的操作系统用户来登录。 如果你是通过使用"psql -U postgres"命令登录PostgreSQL遇到这个错误,那么这意味着你正在尝试使用名为"postgres"的操作系统用户来登录PostgreSQL,但是该用户没有通过Peer认证验证。 解决这个问题,你可以尝试以下几种方法: 1. 使用与PostgreSQL用户相匹配的操作系统用户来登录。确保你正在使用正确的用户名和密码,以及正确的Peer认证配置。 2. 如果你想使用名为"kmjy"的用户登录PostgreSQL,你可以尝试使用以下命令登录: "psql -U kmjy"。确保你已经在PostgreSQL中创建了该用户,并且使用正确的密码进行登录。 3. 如果你无法解决这个问题,你可以尝试修改PostgreSQL的身份验证配置文件pg_hba.conf。在这个文件中,你可以更改或添加适当的身份验证方法来满足你的需求。 总结来说,当出现"psql: error: FATAL: Peer authentication failed for user"的错误时,这意味着登录PostgreSQL时认证失败。你可以尝试使用与PostgreSQL用户相匹配的操作系统用户来登录,或者使用正确的用户名和密码来登录。如果仍然无法解决问题,你可以尝试修改PostgreSQL的身份验证配置文件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [psql: error: FATAL: Peer authentication failed for user &ldquo;postgres](https://blog.csdn.net/FatalFlower/article/details/114025262)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [【PostgreSQL】psql: error: FATAL: Peer authentication failed for user &ldquo;postgres”](https://blog.csdn.net/wuyy0224/article/details/126737268)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值