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”中的关键字部分就可以了。
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
数据转换的同事发现,生产库现在连接不上。小机系统为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
问题解决