maxuproc调整以及杀LOCAL=NO远程连接进程

1 maxuproc调整以及杀LOCAL=NO远程连接进程

1  linux

所有含有关键字“LOCAL=NO”的进程,这是Oracle数据库中远程连接进程的共同特点,因此通过以下命令可以kill掉所有的进程

ps -ef |grep LOCAL=NO|grep -v grep|cut -c 9-15|xargs kill -9

管道符“|”用来隔开两个命令,管道符左边命令的输出会作为管道符右边命令的输入。下面说说用管道符联接起来的几个命令:

“ps -ef”是Red Hat 里查看所有进程的命令。这时检索出的进程将作为下一条命令“grep LOCAL=NO”的输入。

“grep LOCAL=NO”的输出结果是,所有含有关键字“LOCAL=NO”的进程,这是Oracle数据库中远程连接进程的共同特点。

“grep -v grep”是在列出的进程中去除含有关键字“grep”的进程。

“cut -c 9-15”是截取输入行的第9个字符到第15个字符,而这正好是进程号PID。

“xargs kill -9”中的xargs命令是用来把前面命令的输出结果(PID)作为“kill -9”命令的参数,并执行该命令。“kill -9”会强行杀掉指定进程,这样就成功清除了oracle的所有远程连接进程。其它类似的任务,只需要修改“grep LOCAL=NO”中的关键字部分就可以了。

2 aix

kill -9 'ps -ef|grep LOCAL=NO|grep -v grep|awk '{print $2}'

kill -9 `ps -ef | grep LOCAL|grep -v grep awk '{print $2}'`

ps -ef|grep LOCAL=NO|grep -v grep|cut -c 9-15|xargs kill -9

ps -ef|grep LOCAL=NO|grep -v grep|cut -c 9-15|xargs kill -9

ps -ef|grep -v grep|grep LOCAL=NO|awk '{print $2}'|xargs kill -9

ps -ef|grep -v grep|grep LOCAL=NO|awk '{print $2}'|xargs kill -9

 

3 maxuproc调整

数据转换的同事发现,生产库现在连接不上。小机系统为AIX5.3,用oracle用户登录反映很慢,之后提示 0403-030 The fork function failed. Too many processes already exist。 其他用户能够正常登录。

 

看来不是oracle的问题了

# ps -ef|grep oracle|wc

 126    1239   10614

# lsattr -E -l sys0 -a maxuproc

maxuproc 128 Maximum number of PROCESSES allowed per user True

# chdev -l sys0 -a maxuproc='800'

sys0 changed

 

问题解决

你可能感兴趣的:(ORACLE数据库故障处理分析)