tbase symbol lookup error: ./psql: undefined symbol: PQsetErrorContextVisibility

环境

tbase: 2.15.12.3 或者 tbase 2.15.18.5.1 (独立版)

操作系统: centos7.9/rhel7.6

psql来源: tbase_pgxz-5.06.1.1-i.x86_64

问题现象(报错)

使用psql登录数据库报错如下

16:31:16 [root@ddcw21 bin]#./psql -h 192.168.101.51 -p 11345 -U u1 -d postgres
Password for user u1: 
./psql: symbol lookup error: ./psql: undefined symbol: PQsetErrorContextVisibility

原因分析

此报错为libpq.so版本不对

因为本地环境还安装了开源pg库postgresql-libs-9.2.24-4.el7_8.x86_64, 此库包含了libpq.so.5 , 而tbase_pgxz的psql命令认使用的系统库的libpq(也就是开源的pg-lib), 导致版本不对

16:39:11 [root@ddcw21 bin]#ldd psql | grep libpq
	libpq.so.5 => /lib64/libpq.so.5 (0x00007fce6f5c4000)
16:40:36 [root@ddcw21 bin]#rpm -qf /lib64/libpq.so.5
postgresql-libs-9.2.24-4.el7_8.x86_64
16:40:43 [root@ddcw21 bin]#rpm -ql tbase_pgxz | grep libpq.so
/usr/local/install/tbase_pgxz/lib/libpq.so
/usr/local/install/tbase_pgxz/lib/libpq.so.5
/usr/local/install/tbase_pgxz/lib/libpq.so.5.10

解决办法

方法1 (推荐)

添加tbase_pgxz库到系统库

echo '/usr/local/install/tbase_pgxz/lib' >> /etc/ld.so.conf
ldconfig
ldconfig -p | grep libpq.so

方法2

卸载postgresql-libs

rpm -e postgresql-libs

相关文章

显卡天梯图2024最新版,显卡是电脑进行图形处理的重要设备,...
初始化电脑时出现问题怎么办,可以使用win系统的安装介质,连...
todesk远程开机怎么设置,两台电脑要在同一局域网内,然后需...
油猴谷歌插件怎么安装,可以通过谷歌应用商店进行安装,需要...
虚拟内存这个名词想必很多人都听说过,我们在使用电脑的时候...