/etc/passwd/etc/shadow这两个文件可以说是linux系统中最重要的文件之一。如果没有这两个文件或者这两个文件出问题,是无法正常登录linux系统的

/etc/passwd

image-20210111200239047

/etc/passwd由’:’分割成7个部分,每个部分的具体含义是:

①用户名(如第一行中的root就是用户名),代表用户账号的字符串。用户名字符可以是大小写字母、数字、减号(不能出现在首位)、点以及下划线,其他字符不合法。虽然用户名中可以出现点,但不建议使用,尤其是首位为点时,另外减号也不建议使用,因为容易造成混淆。

②存放的就是该账号的口令,为什么是’x’呢?早期的unix系统口令确实是存放在这里,但基于安全因素,后来就将其存放到/etc/shadow中了,在这里只用一个’x’代替。

③这个数字代表用户标识号,也叫做uid。系统识别用户身份就是通过这个数字来的,0就是root,也就是说你可以修改test用户的uid为0,那么系统会认为root和test为同一个账户。通常uid的取值范围是0~65535,0是超级用户(root)的标识号,1~499由系统保留,作为管理账号,普通用户的标识号从500开始,如果自定义建立一个普通用户,你会看到该账户的标识号是大于或等于500的。

④表示组标识号,也叫做gid。这个字段对应着/etc/group 中的一条记录,其实/etc/group/etc/passwd基本上类似。

⑤注释说明,该字段没有实际意义,通常记录该用户的一些属性,例如姓名、电话、地址等等,使用finger的功能时就会显示这些信息

⑥用户的家目录,当用户登录时就处在这个目录下。root的家目录是/root,普通用户的家目录则为/home/username,这个字段是可以自定义的,比如你建立一个普通用户test1,要想让test1的家目录在/data目录下,只要修改/etc/passwd文件中test1那行中的该字段为/data即可。

⑦shell,用户登录后要启动一个进程,用来将用户下达的指令传给内核,这就是shell。Linux的shell有很多种sh, csh, ksh, tcsh, bash等,而Redhat/CentOS的shell就是bash。查看/etc/passwd文件,该字段中除了/bin/bash外还有/sbin/nologin比较多,它表示不允许该账号登录。如果你想建立一个账号不让他登录,那么就可以把该字段改成/sbin/nologin,默认是/bin/bash

/etc/shadow

image-20210111201155385

/etc/passwd类似,用”:”分割成9个部分

①用户名,跟/etc/passwd对应。

②用户密码,这个才是该账号的真正的密码,不过这个密码已经加密过了,但是有些黑客还是能够解密的。所以为了安全,该文件属性设置为600,只允许root读写。

③上次更改密码的日期,这个数字是这样计算得来的,距离1970年1月1日到上次更改密码的日期,例如上次更改密码的日期为2012年1月1日,则这个值就是365*(2012-1970)+1=15331。

④要过多少天才可以更改密码,默认是0,即不限制。

⑤密码多少天后到期。即在多少天内必须更改密码,例如这里设置成30,则30天内必须更改一次密码,否则将不能登录系统,默认是99999,可以理解为永远不需要改。

⑥密码到期前的警告期限,若这个值设置成7,则表示当7天后密码过期时,系统就发出警告告诉用户,提醒用户他的密码将在7天后到期。

⑦账号失效期限。你可以这样理解,如果设置这个值为3,则表示:密码已经到期,然而用户并没有在到期前修改密码,那么再过3天,则这个账号就失效了,即锁定了。

⑧账号的生命周期,跟第三段一样,是按距离1970年1月1日多少天算的。它表示的含义是,账号在这个日期前可以使用,到期后账号作废。

⑨作为保留用的,没有什么意义。

新增/删除用户和用户组

新增一个组

命令:groupadd [-g GID] groupname

不加-g 则按照系统默认的gid创建组,跟用户一样,gid也是从500开始的

-g选项可以自定义gid

删除组

命令: gropudel groupname

增加用户

命令:useradd [-u UID] [-g GID] [-d HOME] [-M] [-s]

-u 自定义UID

-g 使其属于已经存在的某个GID

-d 自定义用户的家目录

-M 不建立家目录

-s 自定义shell

加上了-M选项后,在/etc/passwd文件中test1那行的第六字段依然有/home/test1,可是ls查看该目录时,会提示该目录不存在

-M选项的作用就是不创建用户的家目录

删除用户

命令:userdel [-r] username

-r 选项的作用是删除用户时,连同用户的家目录一起删除

chfn 更改用户的finger

这个功能不是很常用,修改完后,就会在/etc/passwd文件中的test的那一行第五个字段中看到相关信息了,默认是空的

创建/修改一个用户的密码

创建完账户后,默认是没有设置密码的,虽然没有密码,但账户同样登录不了系统。只有设置好密码之后才可以登录系统

命令:passwd [username]

passwd 后面不跟用户名则是更改当前用户的密码,当前用户为root,所以此时修改的是root的密码,后面跟用户名则修改的是用户名的密码

用户身份切换

命令:su [-] username

后面可以跟”-”也可以不跟

在用其他账号登录linux系统,然后使用su - 就可以切换成root身份

可以使用echo $LOGNAME来查看当前登录的用户名

最后修改:2021 年 01 月 12 日
如果觉得我的文章对你有用,请随意赞赏