首页 > 数据库 >GaussDB 客户端工具--gsql常见问题处理

GaussDB 客户端工具--gsql常见问题处理

时间:2025-01-16 09:29:05浏览次数:3  
标签:gsql 常见问题 会话 -- 数据库 连接数 gaussdb 连接

GaussDB-常见问题处理

连接性能问题
  • 开启log_hostname,但是配置错误的DNS导致的连接性能问题。

    连接数据库,通过“show log_hostname”语句,检查数据库中是否开启log_hostname参数。

    如果开启了相关参数,那么数据库内核通过DNS反查客户端所在机器的主机名。如果数据库配置了不正确的/不可达的DNS服务器,导致数据库建立连接过程较慢。此参数的更多信息详见GUC参数log_hostname

  • 数据库内核执行初始化语句较慢导致的性能问题。

    此种情况定位较难,可以尝试使用Linux的命令:strace。

    strace gsql -U MyUserName -d gaussdb -h 127.0.0.1 -p 23508 -r -c '\q'
    Password for MyUserName:

    在屏幕上打印出数据库的连接过程。比如较长时间停留在下面的操作上:

    sendto(3, "Q\0\0\0\25SELECT VERSION()\0", 22, MSG_NOSIGNAL, NULL, 0) = 22
    poll([{fd=3, events=POLLIN|POLLERR}], 1, -1) = 1 ([{fd=3, revents=POLLIN}])

    可以确定是数据库执行“SELECT VERSION()”语句较慢。

    在连接上数据库后,便可以通过执行“explain performance select version()”语句确定初始化语句执行较慢的原因。更多信息,详见《开发指南》中“SQL调优指南 > SQL执行计划介绍”章节。

    另外还有一种场景不太常见:由于DN所在机器的磁盘满或故障,此时所查询等受影响,无法进行用户认证,导致连接过程挂起。解决此问题清理DN的数据盘空间便可。

  • TCP连接创建较慢问题。

    此问题可以参考上面的初始化语句较慢排查的做法,通过strace侦听,如果长时间停留在:

    connect(3, {sa_family=AF_FILE, path="/home/test/tmp/gaussdb_llt1/.s.PGSQL.61052"}, 110) = 0

    或者

    connect(3, {sa_family=AF_INET, sin_port=htons(61052), sin_addr=inet_addr("127.0.0.1")}, 16) = -1 EINPROGRESS (Operation now in progress)

    说明客户端与数据库端建立物理连接过慢,此时应当检查网络是否存在不稳定、网络吞吐量太大的问题。

  • 资源负载满导致连接较慢的问题。

    原因分析:当CPU、内存、I/O负载中的任意一项接近100%时,会出现gsql连接慢的现象。

    问题解决:

    1. 通过top命令等确认CPU使用率;通过free命令确认内存使用情况;通过iostat命令确认I/O负载;还可以通过cm_agent中的监控日志,以及数据库运维平台中的监测记录进行检查。
    2. 针对短时间内大量慢查询导致的峰值负载场景,可通过[数据库服务器的端口号+1]端口连接,查询pg_stat_activity视图;针对慢查询,可以使用系统函数pg_terminate_backend进行查杀会话。
    3. 针对业务量长期超负载情况(即无明显慢查询,或慢查询查杀后但新的查询依然会变成慢查询),应考虑降低业务负载、增加数据库资源的方式进行优化。
创建连接故障
  • gsql: could not connect to server: No route to host

    此问题一般是指定了不可达的地址或者端口导致的。请检查-h参数与-p参数是否添加正确。

  • gsql: FATAL: Invalid username/password,login denied.

    此问题一般是输入了错误的用户名和密码导致的,请联系数据库管理员,确认用户名和密码的正确性。

  • gsql: FATAL: Forbid remote connection with trust method!

    数据库由于安全问题,禁止远程登录时使用trust模式。这时需要修改gs_hba.conf里的连接认证信息。请联系管理员处理。

    请不要修改gs_hba.conf中数据库主机的相关设置,否则可能导致数据库功能故障。建议业务应用部署在数据库之外,而非数据库内部。

  • 在DN连接数据库,添加“-h 127.0.0.1”可以连接,去掉后无法连接问题。

    通过执行SQL语句“show unix_socket_directory”检查DN使用的Unix套接字目录,是否与shell中的环境变量$PGHOST一致。

    如果检查结果不一致,那么修改PGHOST环境变量到GUC参数unix_socket_directory指向的目录。

    关于unix_socket_directory的更多信息,请联系管理员获取。

  • The "libpq.so" loaded mismatch the version of gsql, please check it.

    此问题是由于环境中使用的libpq.so的版本与gsql的版本不匹配导致的,请通过“ldd gsql”命令确认当前加载的libpq.so的版本,并通过修改LD_LIBRARY_PATH环境变量来加载正确的libpq.so。

  • gsql: symbol lookup error: xxx/gsql: undefined symbol: libpqVersionString

    此问题是由于环境中使用的libpq.so的版本与gsql的版本不匹配导致的(也有可能是环境中存在PostgreSQL的libpq.so),请通过“ldd gsql”命令确认当前加载的libpq.so的版本,并通过修改LD_LIBRARY_PATH环境变量来加载正确的libpq.so。

  • gsql: connect to server failed: Connection timed out

    Is the server running on host "xx.xxx.xxx.xxx" and accepting TCP/IP connections on port xxxx?

    此问题是由于网络连接故障造成。请检查客户端与数据库服务器间的网络连接。如果发现从客户端无法PING到数据库服务器端,则说明网络连接出现故障。请联系网络管理人员排查解决。

    ping -c 4 10.10.10.1
    PING 10.10.10.1 (10.10.10.1) 56(84) bytes of data.
    From 10.10.10.1: icmp_seq=2 Destination Host Unreachable
    From 10.10.10.1 icmp_seq=2 Destination Host Unreachable
    From 10.10.10.1 icmp_seq=3 Destination Host Unreachable
    From 10.10.10.1 icmp_seq=4 Destination Host Unreachable
    --- 10.10.10.1 ping statistics ---
    4 packets transmitted, 0 received, +4 errors, 100% packet loss, time 2999ms

  • gsql: FATAL: permission denied for database "gaussdb"

    DETAIL: User does not have CONNECT privilege.

    此问题是由于用户不具备访问该数据库的权限,可以使用如下方法解决。

    1. 使用管理员用户dbadmin连接数据库。
      gsql -d gaussdb -U dbadmin -p 8000

    2. 赋予该用户访问数据库的权限。GRANT CONNECT ON DATABASE gaussdb TO user1;

      实际上,常见的许多错误操作也可能产生用户无法连接上数据库的现象。如用户连接的数据库不存在,用户名或密码输入错误等。这些错误操作在客户端工具也有相应的提示信息。

      gsql -d gaussdb -p 8000
      gsql: FATAL:  database "gaussdb" does not exist
      
      gsql -d gaussdb -U user1 -p 8000
      Password for user user1:
      gsql: FATAL:  Invalid username/password,login denied.

  • gsql: FATAL: sorry, too many clients already,active/non-active: 197/3.

    此问题是由于系统连接数量超过了最大连接数量。请联系数据库DBA进行会话连接数管理,释放无用会话。

    关于查看用户会话连接数的方法如表1

    会话状态可以在视图PG_STAT_ACTIVITY中查看。无用会话可以使用函数pg_terminate_backend进行释放。

    select datid,pid,state from pg_stat_activity;

     datid |       pid       | state  
    -------+-----------------+--------
     13205 | 139834762094352 | active
     13205 | 139834759993104 | idle
    (2 rows)

    其中pid的值即为该会话的线程ID。根据线程ID结束会话。

    SELECT PG_TERMINATE_BACKEND(139834759993104);

    显示类似如下信息,表示结束会话成功。

    PG_TERMINATE_BACKEND
    ----------------------
     t
    (1 row)

    表1 查看会话连接数

    描述

    命令

    查看指定用户的会话连接数上限。

    执行如下命令查看连接到指定用户USER1的会话连接数上限。其中-1表示没有对用户user1设置连接数的限制。

    SELECT ROLNAME,ROLCONNLIMIT FROM PG_ROLES WHERE ROLNAME='user1';
     rolname | rolconnlimit
    ---------+--------------
     user1    |           -1
    (1 row)

    查看指定用户已使用的会话连接数。

    执行如下命令查看指定用户USER1已使用的会话连接数。其中,1表示USER1已使用的会话连接数。

    SELECT COUNT(*) FROM dv_sessions WHERE USERNAME='user1';
    
     count
    -------
         1
    (1 row)

    查看指定数据库的会话连接数上限。

    执行如下命令查看连接到指定数据库gaussdb的会话连接数上限。其中-1表示没有对数据库gaussdb设置连接数的限制。

    SELECT DATNAME,DATCONNLIMIT FROM PG_DATABASE WHERE DATNAME='gaussdb';
    
     datname  | datconnlimit
    ----------+--------------
     gaussdb |           -1
    (1 row)

    查看指定数据库已使用的会话连接数。

    执行如下命令查看指定数据库gaussdb上已使用的会话连接数。其中,1表示数据库gaussdb上已使用的会话连接数。

    SELECT COUNT(*) FROM PG_STAT_ACTIVITY WHERE DATNAME='gaussdb';
     count 
    -------
         1
    (1 row)

    查看所有用户已使用会话连接数。

    执行如下命令查看所有用户已使用的会话连接数。

    SELECT COUNT(*) FROM dv_sessions;
     
     count
    -------
         10
    (1 row)

  • gsql: wait xxx.xxx.xxx.xxx:xxxx timeout expired

    gsql在向数据库发起连接的时候,会有5分钟超时机制,如果在这个超时时间内,数据库未能正常的对客户端请求进行校验和身份认证,那么gsql会退出当前会话的连接过程,并报出如上错误。

    一般来说,此问题是由于连接时使用的-h参数及-p参数指定的连接主机及端口有误(即错误信息中的xxx部分),导致通信故障;极少数情况是网络故障导致。要排除此问题,请检查数据库的主机名及端口是否正确。

  • gsql: could not receive data from server: Connection reset by peer.

    同时,检查DN日志中出现类似如下日志“ FATAL: cipher file "/data/coordinator/server.key.cipher" has group or world access”,一般是由于数据目录或部分关键文件的权限被误操作篡改导致。请参照其他正常实例下的相关文件权限修改。

  • gsql: FATAL: GSS authentication method is not allowed because XXXX user password is not disabled.

    目标DN的gs_hba.conf里配置了当前客户端IP使用"gss"方式来做认证,该认证算法不支持用作客户端的身份认证,请修改到"sha256"后再试。具体操作请联系管理员处理。

    • 请不要修改gs_hba.conf中数据库主机的相关设置,否则可能导致数据库功能故障。
    • 建议业务应用部署在数据库之外,而非数据库内部。
其他故障
  • 出现因“总线错误”(Bus error)导致的core dump或异常退出。

    一般情况下出现此种问题,是进程运行过程中加载的共享动态库(在Linux为.so文件)出现变化;或者进程二进制文件本身出现变化,导致操作系统加载机器的执行码或者加载依赖库的入口发生变化,操作系统出于保护目的将进程终止,产生core dump文件。

    解决此问题,请重试。同时请尽可能避免在升级等运维操作过程中,在数据库内部运行业务程序,避免升级时因替换文件产生此问题。

    此故障的core dump文件的可能堆栈是dl_main及其子调用,它是操作系统用来初始化进程做共享动态库加载的。如果进程已经初始化,但是共享动态库还未加载完成,严格意义上来说,进程并未完全启动。

更多详情请参考GaussDB 文档中心:https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.1.30/productdesc/qlh_03_0001.html

标签:gsql,常见问题,会话,--,数据库,连接数,gaussdb,连接
From: https://blog.csdn.net/Cui_Yuan_666/article/details/145172944

相关文章

  • 【芳心科技】E. 校音器设计
    实物效果图:实现功能:1.采用32位的STM32微控制器处理核心。2.采用无源蜂鸣器进行不同频率的发声模拟。3.采用咪头采集声音信号,并将采集的声音信号频率显示在LCD12864显示屏上,与设定的标准频率进行比较,得出频率差值。原理图:程序源码:视频链接:可前往抖音、B站、快手......
  • 【AIGC提示词系统】时尚精灵:智能化的个性穿搭推荐系统设计
    感谢各位,再次进入全站综合热榜......
  • RPC 源码解析~Apache Dubbo
    解析RPC(远程过程调用)的源码可以帮助你深入理解其工作原理和实现细节。为了更好地进行源码解析,我们选择一个流行的RPC框架——ApacheDubbo作为示例。Dubbo是一个高性能、轻量级的开源JavaRPC框架,广泛应用于企业级应用中。Dubbo的优劣势优势高性能:Dubbo使用Nett......
  • 分别封装精确运算的加减乘除四个方法
    在前端开发中,进行精确的加减乘除运算通常是因为JavaScript的浮点数运算存在精度问题。为了解决这个问题,可以使用一些库,如decimal.js或big.js,或者手动实现这些方法。以下是一个简单的示例,使用JavaScript手动封装精确的加减乘除四个方法:/***精确加法*@param{number}num1......
  • 局部编译
    局部编译为了提升大型小程序项目的开发体验,减少编译耗时的等待时间,开发者工具新增了局部编译功能,允许开发者指定编译的页面列表,避免编译全部小程序代码文件。前置准备下载并安装1.05.2107090或以上版本的开发者工具,下载地址。如何开启局部编译1.在微信开发者工具中添加......
  • 原生支持 TypeScript
    原生支持TypeScript小程序代码包要求代码文件为wxml/wxss/js/json/wxs。如果我们希望使用TypeScript或less去开发小程序,就需要将ts文件或less文件编译成对应的js文件或wxss文件,这个编译过程以前是需要开发者在工具外自行配置。从开发者工具1.05.210910......
  • MobaXterm V24 破解版下载及安装使用教程
    MobaXterm是一款远程终端控制软件,它不仅可以像PuTTY一样通过SSH连接RaspberryPi等开源硬件,并且还能:直接的便携版;内建多标签和多终端分屏;内建SFTP文件传输;内建Xserver,可远程运行X窗口程序;直接支持VNC/RDP/Xdmcp等远程桌面;默认的UTF-8编码;更加友好的串口连接设置;便携版操作更明......
  • 如何让大小不同的图片等比缩放不变形显示在固定大小的div里?写个例子
    在前端开发中,等比缩放图片以适配固定大小的div容器是一个常见的需求。这通常可以通过CSS来实现,确保图片在缩放时不会变形。以下是一个简单的例子,说明如何使用CSS来完成这个任务:HTML结构:首先,创建一个包含图片的div容器。<divclass="image-container"><imgsrc=......
  • 你有自己买过服务器和域名用来搭建博客或者网站吗?
    是的,我曾经购买过服务器和域名来搭建博客或网站。作为一名前端开发者,搭建自己的网站或博客是一个很好的实践和学习机会。购买服务器和域名后,我进行了以下步骤来搭建博客或网站:选择并购买域名:首先,我选择了一个简洁易记的域名,并通过域名注册商进行了购买。购买服务器:接着,我购买......
  • HTML5怎么为输入框添加语音输入的功能呢?
    在HTML5中,你可以使用WebSpeechAPI中的webkitSpeechRecognition接口来实现语音输入的功能。然而,需要注意的是,这个API目前主要是WebKit浏览器(如Chrome和Safari)支持,并且它的前缀webkit也暗示了这一点。此外,这个API在未来的浏览器中可能会被更改或移除,所以在生产环境中使用时需要谨......