Linux账号和权限管理
管理用户账号和组账号,管理目录和文件属性
壹、用户账号和组账号概述
Linux基于用户身份对资源访问进行控制
-
用户账号
- 超级用户、普通用户、程序用户
超级用户:root用户是Linux操作系统中默认的超级用户账号,对本主机拥有最高的权限。系统中超级用户是唯一的。
普通用户:由root用户或其他管理员用户创建,拥有的权限会受到限制,一般只在用户自己的宿主目录中拥有完整权限。
程序用户:在安装Linux操作系统及部分应用程序时,会添加一些特定的低权限用户账号,这些用户一般不允许登录到系统程序的正常运行,比如 bin、daemon、ftp、mail 等。
-
组账号:
-
基本组(私有组)基本组账号只有一个,一般为创建用户时指定得到组(用户第四段)
- 附加组(公共组)用户除了基本组以外,额外添加指定的组
-
-
UID和GID
- UID (User IDentity,用户标识号)
- GID (Group IDentify,组标识号)
root用户账号的 UID和GID 号为固定值 0
程序用户账号的 UID和GID 号默认为 Centos5,6:1-499,Centos7:1-999
普通用户的 UID和GID 号默认为 Centos5,6:500-60000,Centos7:1000-60000
贰、用户账号文件/etc/passwd
保存用户名称、宿主目录、登录Shall等基本信息
man 5 passwd#可查看介绍信息
- 文件位置:/etc/passwd
- 每一行对应一个用户的账号记录
root:x:0:0:root:/root:/bin/bash
- [ ] 字段1:用户帐号的名称
- [ ] 字段2:用户密码占位符“x"
- [ ] 字段3:用户帐号的UID号
- [ ] 字段4:所属基本组帐号的GID号
- [ ] 字段5:用户全名
- [ ] 字段6:宿主目录
- [ ] 字段7:登录Shell信息( /bin/bash为可登陆系统,/sbin/ nologin和/bin/ false为禁止用户登陆系统)
叁、用户帐号文件/etc/shadow
保存用户的密码、账号有效期等信息
- 文件位置:/etc/shadow
- 每一行对应一个用户的密码记录
#默认只有 root 用户能够读取 shadow 文件中的内容,且不允许直接编辑该文件的内容
- [ ] 字段1:用户帐号的名称
- [ ] 字段2:使用MD5加密的密码字串信息,当为“*"或"! !”时表示此用户不能登录到系统。若该字段内容为空,则该用户无须密码登录系统
- [ ] 字段3:上次修改密码的时间,表示从1970年01月01日算起到最近一次修改密码时间隔的天数
- [ ] 字段4:密码的最短有效天数,自本次修改密码后,必须至少经过该天数才能再次修改密码。默认值为0,表示不进行限制
- [ ] 字段5:密码的最长有效天数,自本次修改密码后,经过该天数以后必须再次修改密码。默认值为99999,表示不进行限制
- [ ] 字段6:提前多少天警告用户密码将过期,默认值为7
- [ ] 字段7:在密码过期之后多少天禁用此用户
- [ ] 字段8:帐号失效时间,此字段指定了用户作废的天数(从1970年01月01日起计算),默认值为空,表示账号永久可用。
- [ ] 字段9:保留字段(未使用)
肆、添加用户账号
1、useradd命令(或adduser)
在/etc/passwd 文件和/etc/shadow 文件的末尾增加该用户账号的记录。
useradd [选项] 要创建的用户名
若未明确指定用户的宿主目录,则在/home目录下自动创建与该用户账号同名的宿主目录,并在该目录中建立用户的各种初始配置文件。
若没有明确指定用户所属的组,则自动创建与该用户账号同名的基本组账号,组账号的记录信息将保存到/etc/group 和/etc/gshadow 文件中。
2、常用选项:
-u:指定用户的 UID 号,要求该 UID 号码未被其他用户使用。
-d:指定用户的家目录位置(当与-M 一起使用时,不生效)。只能用绝对路径指定目录,且不需要事先创建目录
-e:指定用户的账户失效时间,可使用 YYYY-MM-DD 的日期格式。
-g:指定用户的基本组名(或使用 GID 号),对应的组名必须已存在。
-G:指定用户的附加组名(或使用 GID 号),对应的组名必须已存在。
-M:不建立家/宿主目录。
-s:指定用户的登录Shell,( 比如/bin/bash为可登陆系统,/sbin/nologin和/bin/ false为禁止用户登陆系统)。
3、为用户账号设置密码passwd
passwd [选项] 用户名
常用选项
-d:清空指定用户的密码,仅使用用户名即可登录系统
-l:锁定用户账户,锁定的用户账户名即可登录系统
-S:查看用户账户的状态(是否被锁定)
-u:解锁用户账户
设置用户密码方法二:
echo "密码" | passwd --stdin 用户名
伍、修改用户账号的属性usermod
usermod [选项] 用户
1、常用选项
-u:修改用户的UID号
-d:修改用户的家目录位置
-e:修改用户的账户失效时间,可使用YYYY-MM-DD的日期格式
-g:修改用户的基本组名(或使用GID号)
-G:修改用户的附加组名(或使用GID号)
-s:指定用户的登录shell
-l:更改用户账号的登录名称
-L:锁定用户账户
-U:解锁用户账户
2、删除用户账号:userdel
userdel [-r]#添加此选项时可将该用户的宿主目录一并删除 用户名
- [ ] 将 nanjing 用户名改为 dongjing,然后删除此用户
陆、用户帐号的初始配置文件
1、用户宿主目录下的初始配置文件只对当前用户有效
文件名 | 介绍 |
---|---|
~/.bash profile | 此文件中的命令将在该用户每次登录时被执行,它会设置一些环境变量,并且会调用该用户的~/.bashrc文件 |
~/.bashrc | 此文件中的命令会在每次打开新的bash shell时(也包括登录系统)被执行,并且会调用/etc/bashrc文件 |
~/.bash_logout | 此文件中的命令将在用户每次退出登录或退出bash shell时执行 |
2、全局配置文件对所有用户有效
文件名 | 介绍 |
---|---|
/etc/profile | 这个文件是为系统全局变量配置文件,可通过重启系统或者执行source /etc/profile命令使profile文件被读取 |
/etc/profile.d/ | 这个文件实际上是/etc/profile的子日录,存放的是一些应用程序所需的启动脚本 |
/etc/bashrc | 每一个运行bash shell的用户都会执行此文件,可通过执行bash命令打开一个新的bash shell时,使bashrc文件被读取 |
先进入 .bashrc 中进行添加
更改完成后重启查看结果
#PATH变量用于设置可执行程序的默认搜索路径
PATH生效的原理:每次启动系统的时候会初始化命令,会执行/etc/profi1e和~/ .bash profile。/etc/profile 会将路径/usr/local/bin、/usr/bin、/usr/local/sbin 、/usr/sbin 追加到PATH中去。然后调用/etc/profile.d 目录下的脚本。
柒、组账号文件
- [ ] 与用户账号文件相类似
/etc/group#保存组账号的基本信息
/etc/gshadow#保存组账号的密码信息
字段(用:来分开) | 介绍 |
---|---|
字段1 | 组账号的名称 |
字段2 | 占位符"x" |
字段3 | 组账号的GID号 |
字段4 | 组账号的用户成员列表(多成员用","隔开)#一般不包括基本组对应的用户账号 |
2、添加组账号 groupadd
-g#指定 GID 号
groupadd -g 1000#GID号设置 要添加的组账号
3、添加删除组成员 gpasswd
设置组账号密码(极少用)、添加/删除组成员
gpasswd [选项] 指定用户 组账号名
vim /etc/group#查看
常用选项
-a:向组内添加一个用户
-d:从组内删除一个用户成员
-M:定义组(重置)成员列表,以逗号分隔
gpasswd -a nanjing china#将此用户添加到china组中
gpasswd -d nanjing china#将此用户从china组中删除
gpasswd -M nanjing,beijing,dongjing china#将这些用户添加(重新定义,以前的用户将被重置)到china组中
4、删除组账号 groupdel
groupdel 组账号名
5、查询账号信息
① group命令
- 查询用户所属的组
group [用户名]
查询的用户名 :用户名 所属的组名
② id命令
- 查询用户身份标识
id [用户名]
③ finger命令
- 查询用户账号的登录属性
#需要先进行安装finger软件包
finger [用户名]
④ w、who、users命令
查询已登录到主机的用户信息
捌、查看文件/目录的权限和归属
- 访问权限
- 读取 r:允许查看文件内容、显示目录列表
- 写入 w:允许修改文件内容,允许在目录中新建、移动、删除文件或子目录
- 可执行 x:允许允许程序、切换目录(cd)
- 归属(所有权)
- 属主:拥有该文件或目录的账户账号(ls -l的第3个字段可以看到)
- 属组:拥有该文件或目录的组账号(ls -l的第4个字段可以看到)
权限项 | 读 | 写 | 执行 | 读 | 写 | 执行 | 读 | 写 | 执行 |
---|---|---|---|---|---|---|---|---|---|
字符表示 | r | w | x | r | w | x | r | w | x |
数字表示 | 4 | 2 | 1 | 4 | 2 | 1 | 4 | 2 | 1 |
权限分配 | 文件所有者 | 文件所有组 | 其他用户 |
可能拥有权限项 | 组合 |
---|---|
--- | 0 |
--x | 1 |
-w- | 2 |
-wx | 3 |
r-- | 4 |
r-x | 6 |
rw- | 6 |
rwx | 7 |
玖、设置文件/目录的权限 chmod
chmod [ugoa] [+-=] [rwx] 文件或目录
或
chmod nnn 文件或目录
-
[ ] "ugoa"表示该权限设置针对的用户类别。(缺省时为a)
- "u"表示文件属性
- "g"代表文件属组内的用户
- "o"代表其他任何用户
-
"a"代表所有用户
-
[ ] "+ - ="表示设置权限的操作动作
- "+"代表增加相应权限
- "-"代表减少相应权限
-
"="代表仅设置对应的权限
- [ ] "rwx"是权限的字符组合形式,也可以拆分使用
- [ ] 每一个"n"代表一个八进制数,每一个数值是"rwx"的数字表示形式和
常用选项
-R:递归修改指定目录下所文件、子目录的归属
chmod 777 aa#目录名/ -R
拾、设置文件和目录的归属 chown
chown命令
vim /etc/passwd#查看
chown 属主 文件或目录
chown :属组 文件或目录
chown 属主:属组 文件或目录
chown 属主.属组 文件或目录
chgrp 属组 文件或目录
常用选项
-R:递归修改指定目录下所文件、子目录的归属
chown 属主:属组 -R 文件或目录
ll -R 指定的文件或目录
拾壹、设置目录和文件的默认权限 umask
umask作用
- 控制新建的文件或者目录的权限
-
默认权限去除umask的权限为新建的文件或者目录的权限
- [ ] umask设置
umask 022#设置数值
- [ ] umask查看
umask
- [ ] 示例
将umask设为000,新建目录或者文件,查看权限
将umask设为022,新建目录或者文件,再查看权限
普通文件最大默认权限为 6(rw)
目录的最大默认权限为 7 (rwx)
umask 默认的值为 022
普通文件
666
022 644
目录
777
022 755
umask abc
777-abc#如果是奇数,文件权限则再多减1变成偶数
目录:最大默认权限777减去umask后3位得出当前创建目录的默认权限
文件:由于文件的权限为偶数,777减去umask后得出的是奇数,则需再减去1变成偶数,由此得出当前创建文件的默认权限
拾贰、总结
用户账号管理(useradd、passwd、usermod、userdel)
组账号管理(groupadd、gpasswd、groupdel)
用户账号文件与组账号文件
查询账号相关信息的命令(groups、id、finger、w)
设置目录与文件权限(chmod)
设置目录与文件归属(chown)