ORACLE查看允许的最大连接数和当前连接数等信息

本文详细介绍了如何通过监控数据库连接数、优化最大连接数设置、检查并发连接和活跃会话,以及分析进程池状态来提升数据库系统的稳定性和性能。通过实施有效的监控策略和调整配置参数,可以确保数据库资源高效利用,防止资源瓶颈,并提高整体应用程序的响应速度。

 目前总结的语句,在查看数据的连接情况很有用 ,写完程序一边测试代码一边查看数据库连接的释放情况有助于分析优化出一个健壮的系统程序来。

1. 当前的数据库连接数

select count(*) from v$process  

2. 数据库允许的最大连接数

select value from v$parameter where name = 'processes'

3. 修改最大连接数:

SQL> alter system set processes=300 scope=spfile;
系统已更改。
SQL> alter system set sessions=300 scope=spfile;
系统已更改。
注:一般只执行第一个命令就可以,session自动更改.

    3.1创建pfile
       SQL>create pfile from spfile;
               注:如果不做此步,可能会导致更改最大连接数之后数据库不能启动现象

4. 重启数据库

SQL> shutdown immediate
SQL> startup
注:shutdown normal正常关闭数据库可能会相当相当的慢呢
shutdown abort 可能会导致启动数据库时很慢。

PS:中间因为没有执行第5步,导致数据库无法启动
通过使用startup pfile='....pfile/init.ora.11320060487'路径为绝对路径。

然后执行create spfile from pfile;数据库就OK了,但是发现前面做的更改没了。
然后重新修改连接数,记得执行第5步,完成。

5. 查看当前有哪些用户正在使用数据

 SELECT osuser, a.username,cpu_time/executions/1000000||'s', b.sql_text,machine  

 from v$session a, v$sqlarea b  

 where a.sql_address =b.address order by cpu_time/executions desc;  SELECT osuser, a.username,cpu_time/executions/1000000||'s', b.sql_text,machine from v$session a, v$sqlarea b where a.sql_address =b.address order by cpu_time/executions desc;

6. 当前的session连接数

 select count(*) from v$session  

7. 并发连接数

select count(*) from v$session where status='ACTIVE' 

8. 最大连接

 show parameter processes   show parameter processes 

9. Sql代码

alter system set processes = value scope = spfile; 

10.查看processes池

select * from v$sgastat where pool='shared pool' and name='processes';

转载于:https://www.cnblogs.com/freemanabc/p/5408792.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值