并行导致的进程数过大无法连接数据库-成都快上网建站

并行导致的进程数过大无法连接数据库

摘要:并行导致的进程数过大无法连接数据库

阅读原文提升阅读体验: https://www.modb.pro/db/22961?cyn 

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都做网站、成都网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的芒康网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

#####数据库并行进程异常
##问题描述
突发主机出现ora_p进程突然增多,导致process满,导致sqlplus无法登录

ERROR:
ORA-00020: maximum number of processes (2000) exceeded

##查看进程:
–外来连接:
ps -ef|grep LOCAL=NO|grep -v grep|wc -l

–本地连接
ps -ef|grep ora|grep -v grep|wc -l
2026
ps -ef|grep ora_p|grep -v grep|wc -l
PS:ora_p148_XXXXXdb1

##排查日志
Fri Mar 20 15:14:12 2020
ORA-00020: maximum number of processes (2000) exceeded
ORA-20 errors will not be written to the alert log for
the next minute. Please look at trace files to see all
the ORA-20 errors.
Process PA47 submission failed with error = 20

##为什么ora进程会这么多,原因在于ora_p这种并发进程有2000多个。
基本定位问题,是由于sql采用了并行导致的

解决方法:
1、由于sqlplus已经登录不上了,所以要杀掉进程,先登录进去看看
由于是并行导致,非连接数过大,所以可以不用关闭监听。
为了防止杀掉数据库自身进程(ora_pmon等),需要筛选杀掉进程,
ps -ef|grep ora_p1|grep -v grep|awk ‘{print $2}’|xargs kill -9

2、待process降下来后,登录sqlplus,找到问题SQL
INST_ID USERNAME OSUSER MACHINE MODULE SQL_ID CNT


     1 NF_XXXX         Administrator   WorkGroup\ECW42E3712K11RR      PL/SQL Developer                    9y8pxh9ax0nyz          687

3、查看执行计划后,确定是并行导致
4、若果想马上想恢复正常,那就杀掉这个sql的会话
SELECT a.“INST_ID”,a.“SQL_ID”,‘kill -9 ‘||b.“SPID” pid_kill,‘alter system kill session ‘’’ || A.SID || ‘,’ || A.SERIAL# ||’’’;’ sid_kill FROM gv g vprocess b WHERE a.“PADDR”=b.“ADDR” AND a.sql_id=’&SQL_ID’;
5、跟踪源头原因,查看监听日志,定位源头
由于是并行,所以在连接上看,只有一条或两条,可以按时间,也可以按主机名,定位主机IP
vim /u01/app/grid/diag/tnslsnr/dzswjnfdb1/listener/alert/log.xml
搜索:ECW42E3712K11RR

20-MAR-2020 15:11:12 * (CONNECT_DATA=(SERVICE_NAME=sngsnfdb)(CID=(PROGRAM=C:\Program?Files??x86?\PLSQL?Developer\plsqldev.exe)(HOST=ECW42E3712K11RR)
(USER=Administrator))) * (ADDRESS=(PROTOCOL=tcp)(HOST=10.10.85.178)(PORT=63350)) * establish * sngsnfdb * 0
20-MAR-2020 15:11:12 * (CONNECT_DATA=(SERVICE_NAME=sngsnfdb)(CID=(PROGRAM=C:\Program?Files??x86?\PLSQL?Developer\plsqldev.exe)(HOST=ECW42E3712K11RR)
(USER=Administrator))) * (ADDRESS=(PROTOCOL=tcp)(HOST=10.10.85.178)(PORT=63351)) * establish * sngsnfdb * 0

更多数据库相关文章: https://www.modb.pro/db?cyn 


文章题目:并行导致的进程数过大无法连接数据库
转载源于:http://kswjz.com/article/jjpoed.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流