更新时间:2022-08-16 GMT+08:00

管理数据库连接

操作场景

数据库默认支持一定数量的连接,管理员用户可以通过管理数据库的连接,了解当前数据库的连接性能,或增加连接限制使更多用户或应用程序可以同时连接到数据库。

支持的连接数规格

集群支持的连接数与集群节点规格有关:

表1 支持连接数规格

参数

节点规格

CN连接数

DN连接数

max_connections

vCPUs < 16

512

CN连接数 * 2

vCPUs > 16 && <= 32

1024

CN连接数 * 2

other

2048

CN连接数 * 2

comm_max_stream,poolsize,max_prepared_transactions策略同max_connections。

查看最大连接数

  1. 使用SQL客户端工具连接集群中的数据库。
  2. 执行以下命令:

    1
    SHOW max_connections;
    

    界面显示的结果与以下信息类似,表示数据库默认支持的最大连接数为200。

    max_connections
    ----------------- 
    200
    (1 row)

查看已使用的连接数

  1. 使用SQL客户端工具连接集群中的数据库。
  2. 支持查看如表2所示的连接数场景。

    表2 查看连接数介绍

    描述

    命令

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

    执行如下命令查看连接到指定用户dbadmin的会话连接数上限。

    1
    SELECT ROLNAME,ROLCONNLIMIT FROM PG_ROLES WHERE ROLNAME='dbadmin';
    

    查询结果类似如下信息,其中“-1”表示没有对用户dbadmin设置连接数的限制。

     rolname  | rolconnlimit
    ----------+--------------
     dwsadmin |           -1
    (1 row)

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

    执行如下命令查看指定用户dbadmin已使用的会话连接数。

    1
    SELECT COUNT(*) FROM V$SESSION WHERE USERNAME='dbadmin';
    

    查询结果类似如下信息,其中,“1”表示dbadmin已使用的会话连接数。

     count
    -------
         1
    (1 row)

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

    执行如下命令查看连接到指定数据库gaussdb的会话连接数上限。

    1
    SELECT DATNAME,DATCONNLIMIT FROM PG_DATABASE WHERE DATNAME='gaussdb';
    

    查询结果类似如下信息,其中“-1”表示没有对数据库gaussdb设置连接数的限制。

     datname  | datconnlimit
    ----------+--------------
     gaussdb |           -1
    (1 row)

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

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

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

    查询结果类似如下信息,其中,“1”表示数据库gaussdb上已使用的会话连接数。

     count 
    -------
         1
    (1 row)

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

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

    1
    SELECT COUNT(*) FROM V$SESSION;
    

    查询结果类似如下信息:

     count
    -------
         10
    (1 row)