oracle进程显示名称揭秘

oracle进程显示名称揭秘

我相信大家在使用oracle的时候都会和我一样存在一个疑问,oracle的一系列进程显示名称“ora_pmon_sid”很有意思,对DBA定位oracle进程问题也很有帮助,
但是这名称是怎样产生的?

首先,我先从oracle的启动步骤开始说明:
1.设置ORACLE_SID
2.启动sqlplus,
sqlplus "/ as sysdba", cd $ORACLE_HOME/bin;./sqlplus "/ as sysdba", $ORACLE_HOME/bin/sqlplus "/ as sysdba"
以上三种方式启动sqlplus时显示的进程名称分别是:
sqlplus, ./sqlplus, /opt/oracle/product/9iR2/bin/sqlplus
切掉后面的字符是安全方面的考虑,因为如果sqlplus后面带用户名和密码的话,其他用户ps -ef就可以看到了。

在linux的实际编程方式是将argv[0]保留,而其他argv[1-n]则清除,但这种清除方式是将argv的字符填充为非可视值。
$ sqlplus "/ as sysdba"
$ ps -ef -o cmd
sqlplus             HOSTNAME=RHEL3 TERM=vt100 ...

$ sqlplus
...
$ ps -ef -o cmd
sqlplus HOSTNAME=RHEL3 TERM=vt100 ...

很明显/ as sysdba就刚好是中间的11个字符,这就证明oracle只是把该字符串填充而已。

接着,sqlplus尝试启动多个$ORACLE_HOME/bin/oracle后台进程,就是pmon,dbwn,smon等进程。
在linux中创建新进程使用fork和exec系列函数,如果需要指定进程显示名称,只需要指定exec中相关参数即可。

fork();
execv("/opt/oracle/product/db/bin/oracle", "ora_dbw0_sid");

通过ps -ef 观察就可以看到该进程名称为ora_dbw0_sid

对于其他的服务端进程,tns监听等都是上述两种方式的变化了。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/13605188/viewspace-629999/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/13605188/viewspace-629999/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值