【问题描述】
linux中创建了一个wxh用户,然后使用su命令切换用户后,终端提示符显示成“bash-4.2$”而不是[root@localhost wxh]#,导致ll等命令无法执行。
[root@localhost xhh]# su wxh
bash-4.2$ ll
bash: ll: 未找到命令
【原因】
没有在home目录下创建对应的目录导致。
【解决方法】
使用root用户登录,再home目录中创建用户对应的文件夹,mkdir /home/user,这里的user是用户的名字,然后执行如下两个命令:
cp /etc/skel/.bashrc /home/wxh
cp /etc/skel/.bash_profile /home/wxh
执行成功后,再次使用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
更多参考