用户和组的相关配置文件

  用户,是计算机识别使用者身份的一种唯一使用标识。

而现实生活中为了方便人类记忆使用等,用户名往往是用便于人类识别的语言来记录的。但事实上计算机并不对人类语言敏感,所以有必要把人类语言跟机器语言对应上。于是,linux给每一个创建用户提供了一个UID。当使用用户名登录时,系统换自动对应UID来识别该用户身份。

而用户名与UID的对应信息就储存在一个名称解析库中。

/etc/passwd

         用户名的名称解析库:/etc/passwd记录了用户名与相应的UID的对应关系以及一些额外的附加信息。

Cat /etc/passwd会看到各用户名的详细信息如下:

用户和组的相关配置文件

每一行都是一个用户的完整信息,并且被‘:分割成7个字段。从左至右依次是:

用户名:密码占位符:UIDGID:用户描述信息:家目录:默认shell

其中第二个字段密码占位符比较特殊。刚开始时这个位置确实是记录密码的,但由于每一个用户对/etc/passwd都有读取权限,所以并不安全。后来,系统对此做了优化,把密码“转移”,只留下了占位符X

/etc/shadow

       刚才提到为了安全起见,/etc/passwd中的密码字符串被“紧急转移,那么转移到哪里去了呢,就是这里/etc/shadow。所以这个文件就只有万能管理员root有读取权限。如此一来“组织就安全多了。同样,我们cat一下看看:

用户和组的相关配置文件用户和组的相关配置文件

       看到了吧,那一串长长的奇怪的字符就是密码了。看不懂的原因是因为做了单向加密。除了一堆看不懂的字符串之外,还有一些密码的期限信息。同样的,使用分隔,分隔出了9个字段。自左向右依次是:

       用户名:加密的密码:最后一次修改时间:密码的最小年龄:密码的最大年龄:密码警告时段:密码禁用期:账户过期日期:保留字段

加密的密码字段又被‘$’分割成了三段:

第一段:‘$6’为加密算法,数字1-6分别代表了六种加密算法:md5sha1sha224sha256sha384sha512

第二段:有八位字符,是一串随机数,被称作salt,盐。

第三段:才是真正的密码转换过来的。

如果密码字段有*或!,表示用户将无法使用密码登陆(但可以使用其他方式登录系统)。此字段也可为空,此时认证为特定的登录名时,不要求密码。然而,一些读取 /etc/shadow文件的应用程序,在密码字段为空时,可能决定禁止任何访问。

最后一次修改时间:代表的是从linux元年197011日算起到用户最后一次修改密码的时间,若设置为0表示用户应该在下次登录系统时修改密码。空字段表示密码年龄功能被禁用。

密码的最小年龄:代表用户修改一次密码后要间隔多长时间才允许再次修改,空字段或0代表没有最小密码年龄。

最大密码年龄:是代表改一个密码经过多长时间后必须再次修改,空字段表示没有限制。如果最大密码年龄小于最小密码年龄,用户将不能修改此密码。

密码警告时段:密码过期之前,提前警告用户的天数。空字段或0表示没有密码警告期。

密码禁用期:密码过期后,仍然接受此密码的天数(在此期间,用户应该在下次登录时修改密码,强制要求。),过了这个期限,使用用户的当前密码将无法登陆。空字段表示不会强制密码过期。

账户过期日期:表示从197011日开始算起的天数。超过这个期限账号无法使用密码登录。即便其密码没有过期该目录也无法使用。

QQ截图20161023205118.png

/etc/group

         Linux是多用户,多任务的操作系统。一个系统上往往会有多个用户,所以为了方便管理这些用户,linux为用户提供了用户组的管理机制。同样的/etc/group就是用来存放组名解析和组的一些有关信息。

用户和组的相关配置文件

         还是用分隔,分隔出了四个字段。分别是:

                   组名:组密码:GID:用户列表

         组密码依然是使用的占位符X,真正的密码已经“转移/etc/gshadow

         GID中存放的是对应组名的组密码。

         用户列表显示了该组中的组成员。

/etc/gshadow

用户和组的相关配置文件

         用户组密码的相关信息。分隔出了四个字段:

                   组名:加密的密码:管理员:成员

         加密了的密码:此密码用于不是此组成员的用户获取此组的权限。此字段可以为空,此时,只有组成员可以获取组权限。 以叹号开始的密码字段意味着密码被锁定。该行的剩余字符表示锁定之前的密码。

         管理员:必须是一个逗号分隔的用户名列表。管理员可以更改组密码和成员。

         成员:以此组为附加组的用户,必须是一个逗号分隔的用户名列表。成员可以免密码访问组。

/etc/login.defs

         /etc/login.defs定义了一些管理用户和用户组时的默认配置。

例如:定义了创建用户时默认会为该用户创建一个邮箱,邮件的存储路径为/var/spool/mail

用户和组的相关配置文件

定义了用户密码的期限信息。

用户和组的相关配置文件

创建用户不指定UID时,系统默认指定UID的范围:

系统用户UID201-999

普通用户UID1000-60000

用户和组的相关配置文件

创建用户时是否为其创建一个家目录:

Yes,是

No,否

用户和组的相关配置文件

删除一个用户时,若其用户组中没有其他用户时,是否把该用户组一并删除:

Yes,是

No,否

用户和组的相关配置文件

创建密码时使用的加密算法:

SHA521

用户和组的相关配置文件

/etc/default/useradd

         从目录名就可以看出,此文件是关于创建用户时的一些默认配置信息。

用户和组的相关配置文件

GROUP=100:当不创建似有组为主组时,使用user组作为主组。

HOME=/home:用户家目录的默认创建位置,默认会在/home创建一个与用户同名的家目录。

INACTIVE=-1:是否启用密码禁用期,-1代表不起用。

EXPIRE=:账号终止日期,不设置代表不启用。

SHELL=/bin/bash:默认使用的shell类型。

SKEL=/etc/skel:用户家目录中的环境文件,默认添加用户的目录默认文件存放位置;也就是说,当我们用adduser添加用户时,用户家目录下的文件,都是从这个目录中复制过去的。

用户和组的相关配置文件

CREATE_MAIL_SPOOL=yes:默认为新创建的用户添加邮箱位置。会在/var/spool/mail下为用户创建一个同名的邮箱。

原创文章,作者:Hulk,如若转载,请注明出处:http://www.178linux.com/53729

(0)
HulkHulk
上一篇 2016-10-23
下一篇 2016-10-23

相关推荐

  • keepalived的安装和配置

    一、简介 Keepalived是一个免费开源的,用C编写的类似于layer3, 4 & 7交换机制软件,具备我们平时说的第3层、第4层和第7层交换机的功能。主要提供loadbalancing(负载均衡)和 high-availability(高可用)功能,负载均衡实现需要依赖Linux的虚拟服务内核模块(ipvs),而高可用是通过VRRP协议实现多台…

    Linux干货 2017-10-30
  • 基础脚本编程练习题

        Shell脚本其实就是以一系列命令组合起来的文本文件,这些命令组合起来完成一个或者一项功能。因为Shell似乎是各UNIX系统之间通用的功能,并且经过POSIX(表示可移植操作系统接口Portable Operating System Interface of UNIX,缩写为 POSIX)的标准化。因此,Sh…

    2017-08-05
  • Shell脚本基础练习

    脚本编程能力是作为运维工程师不可或缺的一项基本技能,各种系统的运维,如果完全靠命令行一条一条命令来执行,工作效率可想而知,而脚本却可以将完成一定功能的各个命令依据一定的流程控制,逻辑判断去完成某种功能,提升工作效率。学习shell脚本,光学习理论是远远不够的,所以在学习中要多多练习,下面就看一些关于shell脚本基础的练习 (1) 编写脚本/root/bin…

    2017-08-05
  • 第8天磁盘管理练习—增加SWAP分区

          SWAP交换空间,指在物理内存不够用时,充当虚拟内存使用。在实际操作中,使用1-2G的一个分区并指定分区类型为SWAP,挂载至SWAP来使用。 一、新增分区 fdisk /dev/sda n     #新增加分区 t   &nb…

    Linux干货 2016-07-04
  • FHS文件系统结构

    FHS文件系统结构 FHS(Filesystem Hierarchy Standard)文件系统层次结构标准是根据无数开发者的经验总结而来的,多数Linux版本采用这种文件组织形式,FHS定义了系统中每个区域的用途、所需要的最小构成的文件和目录同时还给出了例外处理与矛盾处理,并且会维持更新。

    Linux干货 2016-10-29
  • 推荐-LVM

    LVM LVM Linux应用 1.LVM简介 LVM:Logical Volume Manager,逻辑卷管理器。LVM利用Linux内核的device-mapper模块来实现存储系统的虚拟化(系统分区独立于底层硬件)。通过LVM,你可以实现存储空间的抽象化并在上面建立虚拟分区(virtual partitions),可以更简便地扩大和缩小分区,可以增删分…

    2016-04-11