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/