oracle服务的进程名,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监听等都是上述两种方式的变化了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值