文章目录
查看当前用户
whoami
查看当前登录用户名
用户类型
shell控制台的光标在不同用户下是不同的. $是普通管理员,#是系统管理员.
在Ubuntu下,root用户默认是没有密码的,因此也就无法使用(据说是为了安全)。想用root的话,得给root用户设置一个密码:
sudo passwd root
然后登录时用户名输入root,再输入密码就行了。
在Linux 系统中,由于角色不同,权限和所完成的任务也不同;值得注意的是用户的角色是通过UID和识别的,特别是UID, UID必须是唯一的.
可以用命令可以查看系统的所有用户:
sudo vim /etc/passwd
Linux系统用户分为三类:
- 超级用户:拥有对系统的最高管理权限,默认是root用户。
- 普通用户:只能对自己目录下的文件进行访问和修改,具有登录系统的权限,例如上面提到的www用户、ftp用户等。
- 虚拟用户:也叫“伪”用户,这类用户最大的特点是不能登录系统,它们的存在主要是方便系统管理,满足相应的系统进程对文件属主的要求。例如系统默认的bin、adm、nobody用户等,一般运行的web服务,默认就是使用的nobody用户,但是nobody用户是不能登录系统的。
多用户管理
用户和用户组的概念
Linux是一个多用户多任务的分时操作系统,通过建立不同属性的用户,一方面,可以合理的利用和控制系统资源,另一方面也可以帮助用户组织文件,提供对用户文件的安全性保护。每个用户都用一个唯一的用户名和用户口令,在登录系统时,只有正确输入了用户名和密码,才能进入系统和自己的主目录。
用户组是具有相同特征用户的逻辑集合,有时我们需要让多个用户具有相同的权限,那么通过建立一个组,这个组的所有用户都可以具有查看、修改此文件的权限,然后将所有需要访问此文件的用户放入这个组中,那么所有用户就具有了和组一样的权限。
在系统用户文件/etc/passwd中可以看到, 每行字段的第一个是用户名, 第四个就是用户所在的组
root:x:0:0:root:/root:/bin/bash
/etc/group
文件包含所有组, 还可以用命令groups
查看当前登录用户的组内成员. groups dl
查看dl用户所在的组,以及组内成员.
添加用户
命令useradd
和adduser
都可以增加新的用户. 不同之处在于adduser
命令将自动创建用户的家目录/home/username, 还会创建用户同名的组。
adduser命令
root@ubuntu:~# sudo adduser linuxidc
[sudo] password