用户组和权限管理

  • 解释Linux的安全模型

    • 资源分派:

    • Authentication:认证

    • Authorization:授权

    • Accouting|Audition:审计

    • 介绍安全3A

  • 解释用户帐号和组群帐号的目的

    • 使用数字、大写字母、小写字母及特殊字符中至少3种

    • 足够长

    • 使用随机密码

    • 定期更换,不要使用最近曾经使用过的密码

    • 加密机制:

    • 单向加密:哈希算法,原文不同,密文必不同

    • 更改加密算法:

    • authconfig--passalgo=sha256 --update

    • 加密:明文--> 密文

    • 解密:密文--> 明文

    • 相同算法定长输出,获得密文不可逆推出原始数据

    • 雪崩效应:初始条件的微小改变,引起结果的巨大改变

    • md5: message digest, 128bits

    • sha1: secure hash algorithm, 160bits

    • sha224: 224bits

    • sha256: 256bits

    • sha384: 384bits

    • sha512: 512bits

    • 登录用名

    • 用户密码:一般用sha512加密

    • 从1970年1月1日起到密码最近一次被更改的时间

    • 密码再过几天可以被变更(0表示随时可被变更)

    • 密码再过几天必须被变更(99999表示永不过期)

    • 密码过期前几天系统提醒用户(默认为一周)

    • 密码过期几天后帐号会被锁定

    • 从1970年1月1日算起,多少天后帐号失效

    • login name:登录用名(wang)

    • passwd:密码(x)

    • UID:用户身份编号(1000)

    • GID:登录默认所在组编号(1000)

    • GECOS:用户全名或注释

    • home directory:用户主目录(/home/wang)

    • shell:用户默认使用shell (/bin/bash)

    • Linux用户和组的主要配置文件:

    • /etc/passwd:用户及其属性信息(名称、UID、主组ID等)

    • /etc/group:组及其属性信息

    • /etc/shadow:用户密码及其相关属性

    • /etc/gshadow:组密码及其相关属性

    • Linux组的类别

    • 用户的主要组(primary group)

    • 用户必须属于一个且只有一个主组

    • 组名同用户名,且仅包含一个用户,私有组

    • 用户的附加组(supplementary group)

    • 一个用户可以属于零个或多个辅助组

    • Linux安全上下文

    • 进程所能够访问资源的权限取决于进程的运行者的身份

    • 运行中的程序:进程 (process)

    • 以进程发起者的身份运行:

    • root: /bin/cat

    • mage: /bin/cat

    • Linux组:Groupname/GID

    • 管理员组:root, 0

    • 普通组:

    • 系统组:1-499, 1-999(CENTOS7)

    • 普通组:500+, 1000+(CENTOS7)

    • 令牌token,identity

    • Linux用户:Username/UID

    • 管理员:root, 0

    • 普通用户:1-65535

    • 系统用户:1-499, 1-999 (CentOS7)

    • 对守护进程获取资源进行权限分配

    • 登录用户:500+, 1000+(CentOS7)

    • 交互式登录

    • 用户user

    • 组group

    • 安全上下文

    • 组的类别

    • 用户和组的配置文件

    • passwd文件格式

    • shadow文件格式

    • 密码加密

    • 密码的复杂性策略

    • 密码期限

      用户组和权限管理_第1张图片

  • 用户和组管理命令

    • 1、创建用户gentoo,附加组为bin和root,默认shell为/bin/csh,注释信息为"GentooDistribution"

      35a4a1f0-b351-4d17-8451-b0d23739b8a7-1239515.jpg

    • 2、创建下面的用户、组和组成员关系

    • 名字为webs 的组

    • 用户nginx使用webs 作为附属组

    • 用户varnish,也使用webs 作为附属组

    • 用户mysql,不可交互登录系统,且不是webs 的成员,nginx,varnish,mysql密码都是magedu

      用户组和权限管理_第2张图片

    • useradd

    • 新建用户的相关文件和命令

    • usermod

    • userdel

    • 组帐号维护命令

    • groupadd

    • groupmod

    • groupdel

    • 更改组密码

    • 更改和查看组成员

    • 查看用户相关的ID信息

    • 切换用户或以其他用户身份执行命令

    • 设置密码

    • 修改用户密码策略

    • 用户相关的其它命令

    • chfn 指定个人信息

      用户组和权限管理_第3张图片

    • chsh 指定shell

    • finger

      用户组和权限管理_第4张图片

    • useradd -D

      用户组和权限管理_第5张图片

    • useradd[options] LOGIN

    • -u UID

    • -o 配合-u 选项,不检查UID的唯一性

      398db6af-2f61-4567-a6fb-be1d640cfbab-1239515.jpg

    • -g GID:指明用户所属基本组,可为组名,也可以GID

    • -c "COMMENT":用户的注释信息
      第五个字段  /etc/passwd

    • -d HOME_DIR: 以指定的路径(不存在)为家目录

    • -s SHELL: 指明用户的默认shell程序,可用列表在/etc/shells文件中

    • -G GROUP1[,GROUP2,...]:为用户指明附加组,组须事先存在

    • -N 不创建私用组做主组,使用users组做主组

    • -r: 创建系统用户CentOS 6: ID<500,CentOS 7: ID<1000
      用此选项不会创建家目录   给应用程序使用   如需创建需加-m

    • -m 创建家目录,用于系统用户

    • -M 不创建家目录,用于非系统用户

    • 默认值设定:/etc/default/useradd文件中

    • 显示或更改默认设置

    • useradd -D

    • useradd –D -s SHELL

    • useradd –D –b BASE_DIR

    • useradd –D –g GROUP

    • 练习

      用户组和权限管理_第6张图片

      47312417-21a1-4970-b9bb-19bd9651ff37-1239515.jpg

    • /etc/default/useradd

    • /etc/skel/*

    • /etc/login.defs

    • newusers passwd格式文件批量创建用户

      b736f1d7-360b-4e93-88a3-82bd697b9fed-1239515.jpg

      用户组和权限管理_第7张图片

      用户组和权限管理_第8张图片

    • chpasswd 批量修改用户口令

      9a657d31-18ee-4a6c-b790-e0496354b941-1239515.jpg

      7a6c9fed-3fb1-4b05-9845-a5b02d6e21c2-1239515.jpg

    • 批量删除用户

      用户组和权限管理_第9张图片

      用户组和权限管理_第10张图片

      用户组和权限管理_第11张图片

    • 用户属性修改

    • usermod[OPTION] login

    • -u UID: 新UID

    • -g GID: 新主组

    • -G GROUP1[,GROUP2,...[,GROUPN]]]:新附加组,原来的附加组将会被覆盖;若保留原有,则要同时使用-a选项

      用户组和权限管理_第12张图片

    • -s SHELL:新的默认SHELL

    • -c 'COMMENT':新的注释信息

    • -d HOME: 新家目录不会自动创建;若要创建新家目录并移动原家数据,同时使用-m选项

    • -l login_name: 新的名字;

    • -L: lock指定用户,在/etc/shadow 密码栏的增加!

    • -U: unlock指定用户,将/etc/shadow 密码栏的! 拿掉

      用户组和权限管理_第13张图片

    • -e YYYY-MM-DD: 指明用户账号过期日期

    • -f INACTIVE: 设定非活动期限

    • userdel[OPTION]... login

    • -r: 删除用户家目录

      用户组和权限管理_第14张图片


      连带邮箱一同删除

    • groupadd[OPTION]... group_name  

    • 三种方法

      e8671b12-2acb-40c6-942a-3271d3dfd5ff-1239515.jpg

    • -g GID: 指明GID号;[GID_MIN, GID_MAX]

    • -r: 创建系统组

      daa5b0c6-302e-4c06-a459-cd4d5c5ae429-1239515.jpg

      f47b275f-815d-4cb1-a2eb-d49eaf3cd207-1239515.jpg

    • CentOS 6: ID<500

    • CentOS 7: ID<1000

    • 组属性修改:groupmod

    • groupmod[OPTION]... group

    • -n group_name: 新名字

    • -g GID: 新的GID

      b5149152-b4ea-4de5-95ef-8d3d8f7ae544-1239515.jpg

    • 清空组

      0320e608-73b9-46a7-ac65-f2449a431dbb-1239515.jpg

    • 组删除:groupdel

      5c764e23-8615-48b1-9f1b-6038268a4eac-1239515.jpg

    • 不能是主组  

      用户组和权限管理_第15张图片

      75180006-a6ff-4f80-a695-8a09d5c20f9c-1239515.jpg

    • groupdelGROUP

    • -a user 将user添加至指定组中

    • -d user 从指定组中移除用户user

    • -A user1,user2,... 设置有管理权限的用户列表

    • 组密码:gpasswd

    • gpasswd[OPTION] GROUP

    • newgrp命令:临时切换主组

      用户组和权限管理_第16张图片

    • 永久改

      用户组和权限管理_第17张图片

    • 如果用户本不属于此组,则需要组密码

    • groupmems[options] [action]

    • options:

    • -g, --group groupname更改为指定组(只有root)

    • Actions:

    • -a, --add username 指定用户加入组

    • -d, --delete username 从组中删除用户

      1fe03fac-e3f9-4988-9b34-638a9dc9d3f9-1239515.jpg

    • -p, --purge 从组中清除所有成员

    • -l, --list 显示组成员列表

      a8ef8fa4-bdca-491e-a832-7630de83359e-1239515.jpg

    • groups [OPTION].[USERNAME]... 查看用户所属组列表

    • id [OPTION]... [USER]

    • -u: 显示UID

    • -g: 显示GID

    • -G: 显示用户所属的组的ID

    • -n: 显示名称,需配合ugG使用

    • su[options...] [-] [user [args...]]

    • 切换用户的方式:

    • suUserName:非登录式切换,即不会读取目标用户的配置文件,不改变当前工作目录

    • su-UserName:登录式切换,会读取目标用户的配置文件,切换至家目录,完全切换

    • root su至其他用户无须密码;非root用户切换时需要密码

    • 换个身份执行命令:

    • su[-] UserName-c 'COMMAND'

    • 选项:-l --login

    • su-l UserName相当于su-UserName

    • passwd[OPTIONS] UserName: 修改指定用户的密码

    • 常用选项:

    • -d:删除指定用户密码

    • -l:锁定指定用户

    • -u:解锁指定用户

      4e850f07-eea7-472b-a8bf-768be70917f6-1239515.jpg

    • -e:强制用户下次登录修改密码

      c3c893a5-652d-4a3c-9f8a-e697cae5e30b-1239515.jpg

      用户组和权限管理_第18张图片

    • -f:强制操作

      569c3a3d-f402-4401-9d07-c366252d88e0-1239515.jpg

    • -n mindays:指定最短使用期限

    • -x maxdays:最大使用期限

    • -w warndays:提前多少天开始警告

    • -iinactivedays:非活动期限

    • --stdin:从标准输入接收用户密码

    • echo "PASSWORD" | passwd--stdinUSERNAME

      16f35a87-98e0-42ef-a129-2887b06290a1-1239515.jpg

      fdb5f83d-20d5-4dea-83df-f7d50ba1de81-1239515.jpg

    • chage[OPTION]... LOGIN

    • -d LAST_DAY

    • -E --expiredateEXPIRE_DATE

    • -I --inactive INACTIVE

    • -m --mindaysMIN_DAYS

    • -M --maxdaysMAX_DAYS

      用户组和权限管理_第19张图片

    • -W --warndaysWARN_DAYS

    • –l 显示密码策略

      用户组和权限管理_第20张图片

    • 示例:

    • chage-d 0 tom 下一次登录强制重设密码

      用户组和权限管理_第21张图片

      1550045f-04e6-48b9-af50-87c4a7106ffc-1239515.jpg

      用户组和权限管理_第22张图片

    • chage-m 0 –M 42 –W 14 –I 7 tom

    • chage-E 2016-09-10 tom

    • vipw和vigr

    • pwck和grpck

    • 检查信息

      用户组和权限管理_第23张图片

    • grpck检查组信息

      2a49678e-30de-4599-a818-41da26537798-1239515.jpg

      04f86507-190a-4a9f-abaa-26b770e083f3-1239515.jpg

    • 群组名称:就是群组名称

    • 群组密码:

    • 组管理员列表:组管理员的列表,更改组密码和成员

    • 以当前组为附加组的用户列表:(分隔符为逗号)

    • 群组名称:就是群组名称

    • 群组密码:通常不需要设定,密码是被记录在/etc/gshadow

    • GID:就是群组的ID

    • 以当前组为附加组的用户列表(分隔符为逗号)

    • group文件格式

    • gshdow文件格式

    • 文件操作

    • 用户管理命令

    • 练习

  • 理解并设置文件权限

    • 文件的权限主要针对三类对象进行定义

    • 每个文件针对每类访问者都定义了三种权限

    • 文件:

    • 目录:

    • 文件权限操作命令:chmod

    • 文件权限(rwx|X)

    • 八进制数字

    • 修改文件权限

    • 权限设置示例

    • 练习

    • owner: 属主, u

    • group: 属组, g

    • other: 其他, o

    • r: Readable

    • w: Writable

    • x: eXcutable

    • r: 可使用文件查看类工具获取其内容

    • w: 可修改其内容

    • x: 可以把此文件提请内核启动为一个进程

    • r: 可以使用ls查看此目录中文件列表

    • w: 可在此目录中创建文件,也可删除此目录中的文件

    • x: 可以使用ls -l查看此目录中文件元数据(须配合r),可以cd进入此目录

    • X:只给目录x权限,不给文件x权限

    • ---000 0

    • --x 001 1

    • -w-010 2

    • -wx 011 3

    • r--100 4

    • r-x 101 5

    • rw-110 6

    • rwx 111 7

    • 例如:

    • 640: rw-r-----

    • 755: rwxr-xr-x

    • chmod[OPTION]... OCTAL-MODE FILE...

    • -R: 递归修改权限

    • chmod[OPTION]... MODE[,MODE]... FILE...

    • MODE:

    • 修改一类用户的所有权限:

    • u= g= o= ug= a= u=,g=

    • 修改一类用户某位或某些位权限

    • u+ u-g+ g-o+ o-a+ a-+ -

    • chmod[OPTION]... --reference=RFILE FILE...

    • 参考RFILE文件的权限,将FILE的修改为同RFILE

    • chgrp sales testfile

    • chown root:admins testfile

    • chmod  u+wx, g-r ,o=rx file

    • chmod-R g+rwX /testdir

    • chmod 600 file

    • chown mage testfile

    • 不可以改  可以删

    • 不能改 不能删

    • 不知道文件列表  知道文件名可以访问

    • 不能cd   不能访问文件  能看到文件名

    • 1、当用户docker对/testdir目录无执行权限时,意味着无法做哪些操作?

    • 2、当用户mongodb对/testdir目录无读权限时,意味着无法做哪些操作?

    • 3、当用户redis对/testdir目录无写权限时,该目录下的只读文件file1是否可修改和删除?

    • 4、当用户zabbix对/testdir目录有写和执行权限时,该目录下的只读文件file1是否可修改和删除?

    • 5、复制/etc/fstab文件到/var/tmp下,设置文件所有者为tomcat读写权限,所属组为apps组有读写权限,其他人无权限

      用户组和权限管理_第24张图片

    • 6、误删除了用户git的家目录,请重建并恢复该用户家目录及相应的权限属性

      用户组和权限管理_第25张图片

    • 修改文件的属主:chown

    • chown[OPTION]... [OWNER][:[GROUP]] FILE...

    • 用法:

    • OWNER

    • OWNER:GROUP

    • :GROUP

    • 命令中的冒号可用.替换

    • -R: 递归

    • chown[OPTION]... --reference=RFILE FILE...

    • 修改文件的属组:chgrp

    • chgrp[OPTION]... GROUP FILE...

    • chgrp[OPTION]... --reference=RFILE FILE...

    • -R 递归

    • chown设置文件的所有者

    • chgrp设置文件的属组信息

    • 用户组和权限管理_第26张图片

    • 文件权限

    • 文件属性操作

    • 修改文件的属主和属组

    • 文件权限

  • 默认权限

    • umask值可以用来保留在创建文件权限

    • 新建FILE权限: 666-umask

    • 如果所得结果某位存在执行(奇数)权限,则将其权限+1

    • 新建DIR权限: 777-umask

    • 非特权用户umask是002

    • root的umask是022

    • umask: 查看

    • umask#: 设定

    • umask002

    • umask–S 模式方式显示

    • umask–p 输出可被调用

    • 全局设置:/etc/bashrc用户设置:~/.bashrc

    • 新建文件和目录的默认权限

  • 特殊权限

    • 特殊权限

    • suid:4,作用于二进制程序,功能:当用户执行此程序时,将继承此文件所有者的权限

    • sgid:  2,作用于二进制程序,功能:当用户执行此程序时,将继承此文件所有组的权限

    • 作用于目录上,功能:当用户在目录建新文件时,新文件的所属组自动继承此目录的所属组

    • sticky: 1,作用于目录上,功能:此目录中的文件,只能被所有者自已删除。

    • SUID, SGID, Sticky

    • 三种常用权限:r, w, x user, group, other

    • 安全上下文

    • 可执行文件上SUID权限

    • 可执行文件上SGID权限

    • 目录上的SGID权限

    • Sticky 位

    • 特殊权限数字法

    • 权限位映射

    • 设定文件特定属性

    • 练习

    • 删除权限

      用户组和权限管理_第27张图片

    • SUID  运行此程序换为程序所有者的身份

      用户组和权限管理_第28张图片

    • 更改suid权限

      用户组和权限管理_第29张图片

    • SGID 运行此程序换为程序所有组的身份

      用户组和权限管理_第30张图片

    • Sticky  粘滞键    只有文件所有者和root能删除

    • (1) 任何一个可执行程序文件能不能启动为进程,取决发起者对程序文件是否拥有执行权限

    • (2) 启动为进程之后,其进程的属主为发起者,进程的属组为发起者所属的组

    • (3) 进程访问文件时的权限,取决于进程的发起者

    • (a) 进程的发起者,同文件的属主:则应用文件属主权限

    • (b) 进程的发起者,属于文件属组;则应用文件属组权限

    • (c) 应用文件“其它”权限

    • 前提:进程有属主和属组;文件有属主和属组

    • 任何一个可执行程序文件能不能启动为进程:取决发起者对程序文件是否拥有执行权限

    • 启动为进程之后,其进程的属主为原程序文件的属主

    • SUID只对二进制可执行程序有效

    • SUID设置在目录上无意义

    • 权限设定:

    • chmodu+sFILE...

    • chmodu-s FILE...

    • 任何一个可执行程序文件能不能启动为进程:取决发起者对程序文件是否拥有执行权限

    • 启动为进程之后,其进程的属组为原程序文件的属组

    • 权限设定:

    • chmodg+sFILE...

    • chmodg-s FILE...

    • 默认情况下,用户创建文件时,其属组为此用户所属的主组

    • 一旦某目录被设定了SGID,则对此目录有写权限的用户在此目录中创建的文件所属的组为此目录的属组

      用户组和权限管理_第31张图片

    • 通常用于创建一个协作目录

    • 权限设定:

    • chmod  g+s DIR...

    • chmod  g-s  DIR...

    • 具有写权限的目录通常用户可以删除该目录中的任何文件,无论该文件的权限或拥有权

    • 在目录设置Sticky 位,只有文件的所有者或root可以删除该文件

    • sticky 设置在文件上无意义

    • 权限设定:

    • chmod o+t DIR...

    • chmod o-t DIR...

    • 例如:

    • ls-ld/tmpdrwxrwxrwt12rootroot4096Nov215:44/tmp

    • SUID SGID STICKY

    • 000 0

    • 001 1

    • 010 2

    • 011 3

    • 100 4

    • 101 5

    • 110 6

    • 111 7

    • chmod4777 /tmp/a.txt

    • SUID: user,占据属主的执行权限位

    • s:属主拥有x权限

    • S:属主没有x权限

    • SGID: group,占据属组的执行权限位

    • s:group拥有x权限

    • S:group没有x权限

    • Sticky: other,占据other的执行权限位

    • t:other拥有x权限

    • T:other没有x权限

    • chattr+i不能删除,改名,更改

    • chattr+a 只能追加内容

    • lsattr显示特定属性

    • 1、在/testdir/dir里创建的新文件自动属于webs组,组apps的成员如:tomcat能对这些新文件有读写权限,组dbs的成员如:mysql只能对新文件有读权限,其它用户(不属于webs,apps,dbs)不能访问这个文件夹

      用户组和权限管理_第32张图片

    • 2、备份/testdir/dir里所有文件的ACL权限到/root/acl.txt中,清除/testdir/dir中所有ACL权限,最后还原ACL权限

    • Linux文件系统上的特殊权限

  • ACL

    • ACL:Access Control List,实现灵活的权限管理

    • 除了文件的所有者,所属组和其它人,可以对更多的用户设置权限

      用户组和权限管理_第33张图片

    • 为单一用户设置权限

      用户组和权限管理_第34张图片

    • 看权限

      用户组和权限管理_第35张图片

    • CentOS7默认创建的xfs和ext4文件系统具有ACL功能
      文件夹权限与文件系统相关
      fat分区不支持权限

    • CentOS7之前版本,默认手工创建的ext4文件系统无ACL功能,需手动增加

    • ACL生效顺序:所有者,自定义用户,自定义组,其他人

      用户组和权限管理_第36张图片

      用户组和权限管理_第37张图片

    • 为多用户或者组的文件和目录赋予访问权限rwx

    • ACL文件上的group权限是mask 值(自定义用户,自定义组,拥有组的最大权限),而非传统的组权限

      用户组和权限管理_第38张图片

      用户组和权限管理_第39张图片

    • getfacl可看到特殊权限:flags

    • 通过ACL赋予目录默认x权限,目录内文件也不会继承x权限

    • base ACL 不能删除

    • setfacl-k dir 删除默认ACL权限

    • setfacl–b file1清除所有ACL权限

      用户组和权限管理_第40张图片

    • getfaclfile1 | setfacl--set-file=-file2 复制file1的acl权限给file2

    • mask只影响除所有者和other的之外的人和组的最大权限

      用户组和权限管理_第41张图片

    • Mask需要与用户的权限进行逻辑与运算后,才能变成有限的权限(Effective Permission)

      用户组和权限管理_第42张图片

    • 用户或组的设置必须存在于mask权限设定范围内才会生效setfacl-m mask::rx file

      用户组和权限管理_第43张图片

    • --set选项会把原有的ACL项都删除,用新的替代,需要注意的是一定要包含UGO的设置,不能象-m一样只是添加ACL就可以

    • 示例:

    • setfacl --set u::rw,u:wang:rw,g::r,o::-file1

    • 备份和恢复ACL

    • 主要的文件操作命令cp和mv都支持ACL,只是cp命令需要加上-p 参数。但是tar等常见的备份工具是不会保留目录和文件的ACL信息

      用户组和权限管理_第44张图片

      用户组和权限管理_第45张图片

      用户组和权限管理_第46张图片

    • getfacl-R /tmp/dir1 > acl.txt

    • setfacl -R -b /tmp/dir1

    • setfacl-R --set-file=acl.txt/tmp/dir1

    • setfacl--restore acl.txt

      用户组和权限管理_第47张图片

    • getfacl -R /tmp/dir1

    • 备份acl权限丢失     用cp -a f1  /root/f1   可以保留acl权限

      用户组和权限管理_第48张图片

    • tune2fs –o acl/dev/sdb1

    • mount –o acl/dev/sdb1 /mnt/test

    • •mount -o acl/directory

    • •getfaclfile |directory

    • •setfacl-m u:wang:rwx file|directory

    • •setfacl-Rm g:sales:rwx directory    -R递归

      用户组和权限管理_第49张图片

    • setfacl -R -b file| directory 清空acl权限

      用户组和权限管理_第50张图片

    • •setfacl-M file.acl  file|directory   批量设权限

      a3fffe3b-efb0-402e-a40c-9a5991902691-1239515.jpg

      用户组和权限管理_第51张图片

    • 批量删权限

      216b7f87-e12a-4e63-9df5-996b21c63384-1239515.jpg

      用户组和权限管理_第52张图片

    • •setfacl-m g:sales group:rw file| directory

    • •setfacl-m d:u:wang:rx directory    新建文件默认权限

    • •setfacl-x u:wang file |directory

      用户组和权限管理_第53张图片

    • •setfacl-X file.acldirectory

    • 访问控制列表