这是同事处理的一个问题,觉得很有意思。
现象:一个普通用户aaa通过ssh登陆时,~/.bash_profile等bash配置文件没有起作用,例如TERM的提示符没有设置,某些在/etc/profile里的环境变量也没有赋值。
排查:
1. source ~/.bash_profile 能正确读取并设置环境变量,说明~/.bash_profile没错误;
2. 在~/.bash_profile头部增加一些echo提示信息,登陆时依然没有这些echo的输出,说明~/.bash_profile在登陆时根本没有起作用;
3. 查看了/etc/passwd,里面aaa用户确实是使用bash来登陆的;
4. 查看了/bin/bash的权限,被增加了s位,正常系统是没有s位的。
猜测:/bin/bash增加了s位,执行时是以root权限来执行的。于是bash会去读取/root下面的.bash_profile,但是aaa的普通用户没有去读取/root下面文件的权限,于是登陆时~/bash_profile不起作用。
在其他系统上使用chmod ug+s /bin/bash命令增加s位,再使用普通用户登陆,果然复现了该现象。
咨询了用户,曾在/bin下执行过chmod ug+s *命令,所有/bin下面的可执行文件都被加上了s位。