Linux中切换用户出现bash-4.2$问题解决
作者:小慌慌
问题描述
linux中创建了一个xhh用户,然后使用su命令切换用户后,终端提示符显示成“bash-4.2$”而不是[root@localhost xhh]#,导致ll等命令无法执行。
[root@localhost xhh]# su shh bash-4.2$ ll bash: ll: 未找到命令
原因
没有在home目录下创建对应的目录导致。
解决方法
使用root用户登录,再home目录中创建用户对应的文件夹,mkdir /home/user,这里的user是用户的名字,然后执行如下两个命令:
cp /etc/skel/.bashrc /home/xhh cp /etc/skel/.bash_profile /home/xhh
执行成功后,再次使用su命令切换用户,发现一切正常。
附:linux创建普通用户并设置密码及授权
创建用户:useradd username
修改密码:
1、连接上相应的linux主机,进入到等待输入shell指令的linux命令行状态下。
2、其次,在linux命令行中输入:passwd username
。(username为普通用户的名字)
3、最后,按下回车键执行shell指令,此时会看到要求设置用户username的新密码。
设置即可。
锁定用户:passwd -l username
恢复用户:passwd -u username
授权:
直接修改/etc/passwd文件
/etc/passwd文件里的第三列是UID,这个值为0的话就表示这个用户具有完全的管理员权限,所以新建一个用户后只需要把这个值置为0就可以:
修改/etc/sudoers文件里的wheel:
新建一个用户jordan后,按照以下方式修改:
去掉前面的#
然后把username加入到wheel组中:usermod -g wheel username
但是在想形式root权限时需要在前面加上sudo,而且需要每次输入密码,如果嫌麻烦,不想每次都输入密码,可以按照以下方式进行修改:
最后一个ALL前加 NOPASSWD即可。
这时就不再需要每次都输入密码了。
3. 修改 /etc/sudoers 文件,找到下面一行,在root下面添加一行,如下所示:(先把前两步做的操作回滚,保证username用户现在没有管理员权限)
[root@localhost ~]# cat /etc/sudoers # **** ## Allow root to run any commands anywhere root ALL=(ALL) ALL #(为普通用户username赋予root权限) #第一个ALL:所有地方都可以登陆,localhost只能本机登陆。 #第二个(ALL):表示什么身份的用户都执行。' #第三个ALL:表示所有命令都可以使用 #NOPASSWD:表示不用输入root密码即可执行 username ALL=(ALL) NOPASSWD:/usr/bin/netstat,/usr/bin/ps
总结
到此这篇关于Linux中切换用户出现bash-4.2$问题解决的文章就介绍到这了,更多相关Linux切换用户bash-4.2$内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!