管理数据库连接
操作场景
数据库默认支持一定数量的连接,管理员用户可以通过管理数据库的连接,了解当前数据库的连接性能,或增加连接限制使更多用户或应用程序可以同时连接到数据库。
支持的连接数规格
集群支持的连接数与集群节点规格有关:
参数 |
节点规格 |
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。
查看最大连接数
- 使用SQL客户端工具连接集群中的数据库。
- 执行以下命令:
1
SHOW max_connections;
界面显示的结果与以下信息类似,表示数据库默认支持的最大连接数为200。
max_connections ----------------- 200 (1 row)
查看已使用的连接数
- 使用SQL客户端工具连接集群中的数据库。
- 支持查看如表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)