这是看itercast的笔记
Linux用户基础
用户代表一个使用计算机的使用者,操作系统通过用户概念限制一个使用者能够访问的资源
用户
用户ID为32位,从0开始,但为了和老式系统兼容,用户ID限制在60000以下
用户分为以下三种
用户类别 | 用户ID范围 | 备注 |
---|---|---|
root用户 | ID为0 | 超级用户,可以做任何事 |
系统用户 | 1到499 | 一般是服务创建的,没有shell |
普通用户 | 500及以上 |
id用来显示当前用户的ID
passwd来修改用户的密码
相关文件
有三个文件和用户信息相关
文件名 | 文件内容 |
---|---|
/etc/passwd | 保存用户的信息 |
/etc/shadow | 保存加密后的用户密码 |
etc/group | 保存组信息 |
/etc/passwd格式说明
用户名 | 密码 | 用户ID | 组ID | 用户信息 | 用户的家目录 | 用户登陆的shell |
---|---|---|---|---|---|---|
nothi | x(代表密码存在/etc/shadow) | 1000 | 1000 | nothi,,, | /home/nothi | /bin/bash(如果是/bin/false代表没有shell) |
/etc/shadow说明
用户名 | 加密后的密码 | 其它信息 |
---|---|---|
nothi | !!(!!代表没有设密码), 密码分为三部分:加密类型+盐+真正的密码 |
/etc/group格式说明
组名 | 组密码 | 组ID | 其它信息 |
---|---|---|---|
root | x(同样的x代表存在/etc/shadow) | 0 |
查看登陆用户的信息
命令 | 作用 |
---|---|
whoami | 显示当前用户 |
who | 显示登陆用户的信息 |
w | 显示登陆用户的详细信息 |
创建用户
命令useradd用来创建用户, 如useradd nothi
以下是创建用户时,系统的底层操作
- 在/etc/passwd中添加用户信息
- 如果使用passwd命令创建密码,把密码保存在/etc/shadow中
- 为用户建立一个新的家目录
- 将/etc/skel中的文件复制到用户的家目录中
- 建立一个与用户名相同的组,新建的用户属于这个组
命令useradd支持的参数
- -d, 家目录
- -s, 登陆的shell
- -u, userid
- -g, 主族
- -G, 附属组(最多31个,用","分割)
修改用户信息
usermod 参数 用户名
命令usermod的常用参数
- -l 修改用户名
- -u 修改uid
- -g 修改用户主组
- -G 修改用户附属组
- -L 锁定用户
- -U 解锁用户
删除用户
命令userdel用以删除用户名,以下是常见用法
- userdel nothi 保留家目录
- userdel -r nothi 同时删除家目录
组
组是用户的集合,用以管理一系列的用户
创建、修改、删除组
组相关的常用命令
- groupadd 组名,添加组
- groupmod 用以修改组信息
- groupmod -n 新组名 旧组名
- groupmod -g 新组ID 旧组ID
- groupdel删除一个组
参考资料
转载请注明出处--nothi