【⾝份鉴别-⾝份标识】Linux系统⽤户及⽤户组管理
⽬录
1 认识/etc/passwd 和 /etc/shadow
存储帐号的⽂件:/etc/passwd
存储密码的⽂件:/etc/shadow
这两个⽂件可以说是linux系统中最重要的⽂件之⼀。如果没有这两个⽂件或者这两个⽂件出问题,则你是⽆法正常登录linux系统的。1.1 /etc/passwd
[root@localhost ~]# cat /etc/passwd | head
root : x : 0 : 0 : root : /root : /bin/bash
bin : x : 1 : 1 : bin : /bin : /sbin/nologin
你是不是对上⾯的命令有点不知所以,”head” 前⾯的 “|” 我们叫做管道符,它的作⽤是把前⾯的命令的输出再输⼊给后⾯的命令。管道符会在后⾯章节中提及,这个符号⽤的也是蛮多的,请掌握它的⽤法。
‘/etc/passwd’ 由 ‘:’ 分割成7个字段,每个字段的具体含义是:
1. ⽤户名(如第⼀⾏中的root就是⽤户名),代表⽤户账号的字符串。⽤户名字符可以是⼤⼩写字母、数字、减号(不能出现在⾸
位)、点以及下划线,其他字符不合法。虽然⽤户名中可以出现点,但不建议使⽤,尤其是⾸位为点时,另外减号也不建议使⽤,因为容易造成混淆。
2. ⼝令 存放的就是该账号的⼝令,为什么是 ‘x’ 呢?早期的unix系统⼝令确实是存放在这⾥,但基于安全因素,后来就将其存放到
‘/etc/shadow’ 中了,在这⾥只⽤⼀个 ‘x’ 代替。
3. UID  这个数字代表⽤户标识号,也叫做uid。系统识别⽤户⾝份就是通过这个数字来的,0就是root,也就是说你可以修改test⽤户的
uid为0,那么系统会认为root和test为同⼀个账户。通常uid的取值范围是0~65535(但实际上已经可以⽀持到4294967294),0是超级⽤户(root)的标识号,1~499由系统保留,作为管理账号,普通⽤户的标识号从500开始,如果我们⾃定义建⽴⼀个普通⽤户,你会看到该账户的标识号是⼤于或等于500的。
4. GID 表⽰组标识号,也叫做gid。这个字段对应着/etc/group 中的⼀条记录,其实/etc/group和/etc/passwd基本上类似。
5. 注释说明,该字段没有实际意义,通常记录该⽤户的⼀些属性,例如姓名、电话、地址等等。不过,当你使⽤finger的功能时就会显
⽰这些信息的(稍后做介绍)。
6. ⽤户的HOME⽬录,当⽤户登录时就处在这个⽬录下。root的家⽬录是/root,普通⽤户的家⽬录则为/home/username,这个字段
是可以⾃定义的,⽐如你建⽴⼀个普通⽤户test1,要想让test1的家⽬录在/data⽬录下,只要修改/etc/passwd⽂件中test1那⾏中的该字段为/data即可。
7. shell,⽤户登录后要启动⼀个进程,⽤来将⽤户下达的指令传给内核,这就是shell。Linux的shell有很多种sh, csh, ksh, tcsh,
bash等,⽽Redhat/CentOS的shell就是bash。查看/etc/passwd⽂件,该字段中除了/bin/bash外还有/sbin/nologin⽐较多,它表⽰不允许该账号登录。如果你想建⽴⼀个账号不让他登录,那么就可以把该字段改成/sbin/nologin,默认是/bin/bash.
1.2 /etc/shadow
再来看看/etc/shadow这个⽂件,和/etc/passwd类似,⽤ ‘:’ 分割成9个字段。
每个字段的含义是:
1. ⽤户名,跟/etc/passwd对应。
2. ⽤户密码,这个才是该账号的真正的密码,不过这个密码已经加密过了,但是有些⿊客还是能够解密的。所以,该⽂件属性设置为
000,但是root账户是可以访问或更改的。
hostname用法3. 上次更改密码的⽇期,这个数字是这样计算得来的,距离1970年1⽉1⽇到上次更改密码的⽇期,例如上次更改密码的⽇期为2012
年1⽉1⽇,则这个值就是 ‘365 x (2012-1970) + (2012-1970)/4 + 1 = 15341’. 因为如果是闰年,则有366天。
4. 要过多少天才可以更改密码,默认是0,即不限制。
5. 密码多少天后到期。即在多少天内必须更改密码,例如这⾥设置成30,则30天内必须更改⼀次密码,否则将不能登录系统,默认是
99999,可以理解为永远不需要改。
6. 密码到期前的警告期限,若这个值设置成7,则表⽰当7天后密码过期时,系统就发出警告告诉⽤户,提醒⽤户他的密码将在7天后到
期。
7. 账号失效期限。你可以这样理解,如果设置这个值为3,则表⽰:密码已经到期,然⽽⽤户并没有在到期前修改密码,那么再过3天,
则这个账号就失效了,即锁定了。
8. 账号的⽣命周期,跟第三段⼀样,是按距离1970年1⽉1⽇多少天算的。它表⽰的含义是,账号在这个⽇期前可以使⽤,到期后账号
作废。
9. 作为保留⽤的,没有什么意义。
2 新增/删除⽤户和⽤户组
2.1 新增⼀个组
命令 : groupadd
语法 : groupadd [-g GID] groupname
[root@localhost ~]# groupadd grptest1
[root@localhost ~]# tail -n1 /etc/group
grptest1:x:502:
不加 “-g” 选项则按照系统默认的gid创建组,跟⽤户⼀样,gid也是从500开始的。
[root@localhost ~]# groupadd -g 511 grptest2
[root@localhost ~]# tail -n2 /etc/group
grptest1:x:502:
grptest2:x:511:
“-g” 选项可以⾃定义gid.
2.2 删除组
命令 : groupdel
structure英英解释[root@localhost ~]# groupdel grptest2
linux的用途和基本使用方法[root@localhost ~]# tail -n3 /etc/group
testgroup:x:500:
user1:x:501:
grptest1:x:502:
该命令没有特殊选项,但有⼀种情况不能删除组:
[root@localhost ~]# groupdel user1
groupdel: cannot remove the primary group of user 'user1'
这是因为user1组中包含user1账户,只有删除user1账户后才可以删除该组。
2.3 增加账户
命令 : useradd
语法 : useradd [-u UID] [-g GID] [-d HOME] [-M] [-s]
‘-u’ ⾃定义UID
‘-g’ 使其属于已经存在的某个组,后⾯可以跟组id, 也可以跟组名
‘-d’ ⾃定义⽤户的家⽬录
‘-M’ 不建⽴家⽬录
‘-s’ ⾃定义shell
[root@localhost ~]# useradd test10
[root@localhost ~]# tail -n1 /etc/passwd
test10:x:500:503::/home/test10:/bin/bash
[root@localhost ~]# tail -n1 /etc/group
test10:x:503:
‘useradd’ 不加任何选项直接跟⽤户名,则会创建⼀个跟⽤户名同样名字的组。
[root@localhost ~]# useradd -u510 -g 513 -M -s /sbin/nologin user11
useradd: group '513' does not exist
[root@localhost ~]# useradd -u510 -g 502 -M -s /sbin/nologin user11
[root@localhost ~]# useradd -u511 -g grptest1 user12
[root@localhost ~]# tail -n2 /etc/passwd
user11:x:510:502::/home/user11:/sbin/nologin
user12:x:511:502::/home/user12:/bin/bash
[root@localhost ~]# tail -n2 /etc/group
grptest1:x:502:
test10:x:503:
‘-g’ 选项后⾯跟⼀个不存在的gid会报错,提⽰该组不存在。刚刚上⾯说过 ‘-M’ 选项加上后则不建⽴⽤户家⽬录,但是
在/etc/passwd⽂件中仍然有这个字段。但是你使⽤ ls /home/user11 查看⼀下会提⽰该⽬录不存在。所以 ‘-M’ 选项的作⽤只是不创建那个⽬录。
[root@localhost ~]# ls /home/user11
ls: ⽆法访问/home/user11: 没有那个⽂件或⽬录
2.4 删除账户
命令 : userdel
语法 : userdel [-r] username
[root@localhost ~]# ls -ld /home/user12
drwx------ 3 user12 grptest1 4096 5⽉  11 07:12 /home/user12
[root@localhost ~]# userdel user12
[root@localhost ~]# ls -ld /home/user12
drwx------ 3 511 grptest1 4096 5⽉  11 07:12 /home/user12
第二类压力容器的范围[root@localhost ~]# ls -ld /home/test10/
drwx------ 3 test10 test10 4096 5⽉  11 07:09 /home/test10/
[root@localhost ~]# userdel  -r test10
[root@localhost ~]# ls -ld /home/test10/
ls: ⽆法访问/home/test10/: 没有那个⽂件或⽬录
‘-r’ 选项的作⽤只有⼀个,就是删除账户的时候连带账户的家⽬录⼀起删除。
3 chfn 更改⽤户的finger (不常⽤)
阿铭⼏乎没有⽤过这个功能,只简单介绍⼀下即可,⽽你也许了解⼀下即可。前⾯内容中提到了findger,即在/etc/passwd⽂件中的第5个字段中所显⽰的信息,那么如何去设定这个信息呢?
[root@localhost ~]# chfn user11
Changing finger information for user11.
Name []: user11
Office []: user11's office
Office Phone []: 12345678
Home Phone []: 123456789
Finger information changed.
[root@localhost ~]# grep 'user11' /etc/passwd
user11:x:510:502:user11,user11's office,12345678,123456789:/home/user11:/sbin/nologin
‘chfn’ 命令可以修改⽤户的findger信息,⽐如name, office, office phone 以及 Home phone.修改完后,就会在/etc/passwd⽂件中的user11的那⼀⾏第五个字段中看到相关信息了,默认是空的。 在本例中,阿铭使⽤了 “grep” 命令,它是⽤来过滤指定关键词的⾏,阿铭会在以后的章节中详细介绍它的⽤法。
4 创建/修改⼀个⽤户的密码
命令 : passwd
语法 : passwd [username]
等创建完账户后,默认是没有设置密码的,虽然没有密码,但该账户同样登录不了系统。只有设置好密码后⽅可登录系统。为⽤户创建密码时,为了安全起见,请尽量设置复杂⼀些。你可以按照这样的规则来设置密码:
1. 长度⼤于10个字符;
aluminum
2. 密码中包含⼤⼩写字母数字以及特殊字符 ‘*’, ‘&’, ‘%’ 等;
3. 不规则性(不要出现root, happy, love, linux, 7758520, 111111等等单词或者数字);
4. 不要带有⾃⼰名字、公司名字、⾃⼰电话、⾃⼰⽣⽇等。
[root@localhost ~]# passwd
更改⽤户 root 的密码。
新的密码:
linux修改口令的命令
重新输⼊新的密码:
passwd:所有的⾝份验证令牌已经成功更新。
“passwd” 后⾯不加username则是修改当前账户的密码。如果你登陆的是root账户,后⾯可以跟普通账户的名字,意思是修改指定账户的密码。
[root@localhost ~]# passwd user11
更改⽤户 user11 的密码。
新的密码:
重新输⼊新的密码:
passwd:所有的⾝份验证令牌已经成功更新。
只有root才可以修该其他账户的密码,普通账户只能修改⾃⼰的密码,其他账户的密码是不可以修改的。
命令 : mkpasswd
这个命令阿铭经常⽤来⽣成密码,省的⾃⼰去想。默认你的Linux是没有这个命令的,需要安装⼀个包 “expect”, 如果你的CentOS可以上⽹,请使⽤命令 yum install -y expect 即可完成安装。安装好后,输⼊命令:
[root@localhost ~]# mkpasswd
HXut8oy*8
⽣成的随机字符串就可以作为⼀个密码,只不过这个密码不容易记忆,没有关系,阿铭等会介绍⼀个⼩⼯具来帮你记录密码,⽽且很安全。
5 ⽤户⾝份切换
Linux系统中,有时候普通⽤户有些事情是不能做的,除⾮是root⽤户才能做到。这时就需要临时切换到root⾝份来做事了。下⾯阿铭带你做⼀个⼩实验,创建 “test” 账户,并修改其密码,这样我们就可以使⽤test账户登陆Linux了。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。