本文共 3505 字,大约阅读时间需要 11 分钟。
[20170705]理解linux su命令.txt
--//我一般在维护时经常使用root用户登录,然后su - oracle 转到其他用户操作
--//一般都加入 - 参数.这个已经成了条件反射...^_^.# man su
Change the effective user id and group id to that of USER.-, -l, --login
make the shell a login shell--//也就是使用login里面的shell,设置好对应的环境.
--//如果执行没有-,也就是仅仅run a shell with substitute user and group IDs,不替换里面的环境变量或者相关参数.1.测试1:
--//当前以root用户登录: # id uid=0(root) gid=0(root) groups=0(root),1(bin),2(daemon),3(sys),4(adm),6(disk),10(wheel) # echo $ORACLE_HOME # export aaa=test # echo $aaa test# su - oracle
$ id uid=1001(oracle) gid=1001(oinstall) groups=101(fuse),1001(oinstall),1002(dba),1003(racoper),1004(asmdba)$ echo $aaa
--//无显示.
$ echo $ORACLE_HOME
/u01/app/oracle/product/11.2.0.4/dbhome_12.如果执行不加参数 - 呢?
$ echo $ORACLE_HOME
--//环境变量ORACLE_HOME没有设置,而root设置的环境变量aaa呢?
$ echo $aaa test--//可以发现可以显示环境变量aaa.
3.这样看来应该很少使用-参数.
--//实际上rac的管理oracle引入许多东西,建立grid用户.通过一些特殊例子来说明问题: --//以grid用户登录: [grid@dm01dbadm02 ~ ]$ ocrcheck Status of Oracle Cluster Registry is as follows : Version : 3 Total space (kbytes) : 262120 Used space (kbytes) : 3852 Available space (kbytes) : 258268 ID : 2101855892 Device/File Name : +DBFS_DG Device/File integrity check succeeded Device/File not configured Device/File not configured Device/File not configured Device/File not configured Cluster registry integrity check succeeded Logical corruption check bypassed due to non-privileged user--//OK.如果你加入参数:
$ ocrcheck -local PROTL-602: Failed to retrieve data from the local registry PROCL-26: Error while accessing the physical storage Operating System error [Permission denied] [13]--//跟踪看看:
$ strace -f -o /tmp/b1.txt ocrcheck -local PROTL-602: Failed to retrieve data from the local registry PROCL-26: Error while accessing the physical storage Operating System error [Permission denied] [13]$ grep 'Permission denied' /tmp/b1.txt
14849 open("/u01/app/11.2.0.4/grid/cdata/dm01dbadm02.olr", O_RDONLY|O_SYNC) = -1 EACCES (Permission denied)--//要打开文件/u01/app/11.2.0.4/grid/cdata/dm01dbadm02.olr.
$ ls -l /u01/app/11.2.0.4/grid/cdata/dm01dbadm02.olr
-rw------- 1 root oinstall 272756736 2017-07-05 09:45:15 /u01/app/11.2.0.4/grid/cdata/dm01dbadm02.olr --//注意看用户,组是root,oinstall,grid用户根本没有权限打开这个文件.--//要解决这个问题一些dba采用把root用户里面加入grid的许多环境变量.以root用户执行,不过这样我认为不是很好!!
--//实际上很简单的方法就是切换到root用户执行,注意这个时候不能加入- 参数,因为这样grid的环境参数就丢失了,实际上这样就以 --//root用户执行,而使用的环境还是grid用户的.$ su root
Password:# id
uid=0(root) gid=0(root) groups=0(root),1(bin),2(daemon),3(sys),4(adm),6(disk),10(wheel) # echo $PATH /usr/local/bin:/bin:/usr/bin:/u01/app/11.2.0.4/grid/bin:.:/u01/app/11.2.0.4/grid/bin# echo $ORACLE_HOME
/u01/app/11.2.0.4/grid--//你可以发现grid的环境参数还在.这个使用以root用户执行如下:
# ocrcheck -local Status of Oracle Local Registry is as follows : Version : 3 Total space (kbytes) : 262120 Used space (kbytes) : 2800 Available space (kbytes) : 259320 ID : 1632195400 Device/File Name : /u01/app/11.2.0.4/grid/cdata/dm01dbadm02.olr Device/File integrity check succeeded Local registry integrity check succeeded Logical corruption check succeeded--//当然还可以以另外的方式,就是使用sudo命令. sudo ocrcheck -local
--//注意要修改/etc/sudoers,加入: grid ALL=(ALL) ALL$ sudo ocrcheck -local
[sudo] password for grid: Status of Oracle Local Registry is as follows : Version : 3 Total space (kbytes) : 262120 Used space (kbytes) : 2800 Available space (kbytes) : 259320 ID : 1632195400 Device/File Name : /u01/app/11.2.0.4/grid/cdata/dm01dbadm02.olr Device/File integrity check succeeded Local registry integrity check succeeded Logical corruption check succeeded转载地址:http://mfmxo.baihongyu.com/