oracle用户下切换用户失败,切换用户时提示:cannot change directory to /home/oracle: Permission denied...

su: /bin/bash: Permission denied带来的疑惑

徒弟说是在死机后出现下面的问题。

在root用户下,su到一个普通用户oracle,得到如下错误:

[root@localhost ~]# su - oracle

su: warning: cannot change directory to /home/oracle: Permission denied

su: /bin/bash: Permission denied

而oracle用户也无法通过直接登录,出现同样错误。

这是一个非常奇怪的问题,到底是什么导致的呢?思路如下:

1,程序执行权限问题

2,程序依赖的共享库权限问题

3,目录权限问题

4,根空间问题。

检查/bin/bash,权限正确,检查/home/oracle权限正确,检查/lib/ld-***.so,权限也正确。

继续调试,检查/etc/passwd,将oracle的home设置为/tmp,把/tmp设置为777,这个权限应该是最宽松的。

而su出现同样的错误。

也就是oracle用户无法访问777权限的/tmp。

问题到底出现在哪里呢?

最后

通过star命令,看到了问题根本,

[root@localhost ~]#stat /

输出如下:因为你ls是看不到的。

File: “/”

Size: 1024            Blocks: 2          IO Block: 1024   目录

Device: 803h/2051d      Inode: 2           Links: 22

Access: (0666/drw-rw-rw-) Uid: (    0/    root)   Gid: (    0/    root)

Access: 2007-12-01 22:28:48.000000000 +0800

Modify: 2007-12-01 22:28:34.000000000 +0800

Change: 2007-12-01 23:17:35.000000000 +0800

问题出来了,这里的权限是错误的,X权限的丢失造成的。

[root@localhost ~]#chmod 755 /

修改后,问题消失。

产生上述问题的方法:

第一种,chmod 666 /,可以导致。

或者,

第二种,chmod 700 /lib/ld-xxxx.so,也可以导致su失败。

有兴趣可以自己试一下。

/ 权限的丢失对于各种运行在自己用户身份上的daemon也存在同样的影响。

上述是转载的内容。

前几天,徒弟也出现了同样的问题,主要的原因考虑为不明原因的死机后重启出现问题。可以直接考虑根空间权限出现问题,不过我这里还没有正常根空间权限的数据,请徒弟看到了,在正常的情况下,对根空间进行STAT,把状态数据记录下来,好以后用于比较。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值