搜索
简帛阁>技术文章>linux系统用户以及用户组管理

linux系统用户以及用户组管理

认识/etc/passwd和/etc/shadow

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

[root@localhost ~]# cat /etc/passwd | head
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
[root@localhost ~]# 

  /etc/passwd由“:”分割成7个字段,每个字段的具体含义是:

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

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

  3)这个数字代表户标识号,也叫做uid。系统识别用户身份就是通过这个数字来的,0就是root,也就是说你可以修改test用户的uid为0,那么系统会认为root和test为同一账户。

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

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

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

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

[root@localhost ~]# cat /etc/shadow
root:$6$YeN8c9qp$kF/ccExwxWD56sKqq0fDZDGO5D4.OLivV2v3L.2wvG8uDlb9sK2zQtw9gij37AOeAE/8gdAObi8sU0A7YE.tC0:17753:0:99999:7:::
bin:*:17632:0:99999:7:::
daemon:*:17632:0:99999:7:::
adm:*:17632:0:99999:7:::
lp:*:17632:0:99999:7:::
sync:*:17632:0:99999:7:::
shutdown:*:17632:0:99999:7:::
halt:*:17632:0:99999:7:::
mail:*:17632:0:99999:7:::
operator:*:17632:0:99999:7:::
games:*:17632:0:99999:7:::
ftp:*:17632:0:99999:7:::
nobody:*:17632:0:99999:7:::
systemd-network:!!:17743::::::
dbus:!!:17743::::::
polkitd:!!:17743::::::
sshd:!!:17743::::::
postfix:!!:17743::::::
mysql:!!:17745:0:99999:7:::
www:!!:17746:0:99999:7:::

  再来看看/etc/shadow这个文件,和/etc/passwd类似,用“:”分割成9个字段。

  1)用户名,跟/etc/passwd对应

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

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

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

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

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

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

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

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

 新增、删除用户和用户组

  1、新增一个组 groupadd [-g GID] groupname

[root@localhost ~]# groupadd grptest1
[root@localhost ~]# tail -n 5 /etc/group
postfix:x:89:
mysql:x:1000:
www:x:1001:
zhouguowei:x:1002:
grptest1:x:1003:
[root@localhost ~]# 

  不加-g则按照系统默认的gid创建组。

[root@localhost ~]# groupadd -g 1004 grptest2
[root@localhost ~]# tail -n 5 /etc/group
mysql:x:1000:
www:x:1001:
zhouguowei:x:1002:
grptest1:x:1003:
grptest2:x:1004:
[root@localhost ~]# 

  -g选项可以自定义gid

  2、删除组 groupdel groupname

[root@localhost ~]# groupdel grptest1
[root@localhost ~]# groupdel grptest2
[root@localhost ~]# tail -n 5 /etc/group
postdrop:x:90:
postfix:x:89:
mysql:x:1000:
www:x:1001:
zhouguowei:x:1002:
[root@localhost ~]# 

  3、增加用户 useradd [-u UID] [-g GID] [-d HOME] [-M] [-s]

  -u自定义UID

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

  -d自定义用户的家目录

  -M不建立家目录

  -s自定义shell

[root@localhost ~]# useradd test10
[root@localhost ~]# tail -n 5 /etc/passwd
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
mysql:x:1000:1000::/home/mysql:/bin/bash
www:x:1001:1001::/home/www:/bin/bash
zhouguowei:x:1002:1002::/home/zhouguowei:/bin/bash
test10:x:1003:1003::/home/test10:/bin/bash
[root@localhost ~]# useradd -u 1004 -g 1004 -M -s /sbin/nologin test11
[root@localhost ~]# tail -n 5 /etc/passwd
mysql:x:1000:1000::/home/mysql:/bin/bash
www:x:1001:1001::/home/www:/bin/bash
zhouguowei:x:1002:1002::/home/zhouguowei:/bin/bash
test10:x:1003:1003::/home/test10:/bin/bash
test11:x:1004:1004::/home/test11:/sbin/nologin
[root@localhost ~]# cd /home
[root@localhost home]# ls
mysql  test10  www  zhouguowei
[root@localhost home]# 

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

  4、删除用户userdel [-r] username

[root@localhost home]# userdel test11
[root@localhost home]# userdel -r test10
[root@localhost home]# ls /home/test10
ls: cannot access /home/test10: No such file or directory
[root@localhost home]# 

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

 chfn更改用户finger

  前面内容中提到了finger,即在/etc/passwd文件中的第5个字段中所显示的信息,那么如何去设定这个信息呢?

[root@localhost home]# chfn test
Changing finger information for test.
Name []: test
Office []: test'office
Office Phone []: 123456789
Home Phone []: 123654789

Finger information changed.
[root@localhost home]# tail -n 5 /etc/passwd
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
mysql:x:1000:1000::/home/mysql:/bin/bash
www:x:1001:1001::/home/www:/bin/bash
zhouguowei:x:1002:1002::/home/zhouguowei:/bin/bash
test:x:1003:1003:test,test'office,123456789,123654789:/home/test:/bin/bash
[root@localhost home]# 

  就是chfn这个命令。修改完后,就会在/etc/passwd文件中的那一行第5个字段中看到相关信息了,默认是空的。

创建、修改一个用户的密码 passwd [username]

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

[root@localhost home]# passwd
Changing password for user root.
New password: 
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@localhost home]# passwd test
Changing password for user test.
New password: 
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@localhost home]# 

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

用户身份切换

  在linux系统中,有时候普通用户有些事情是不能做的,除非是root用户才能做到。这是就需要切换到root身份来做事了。

  用test账号登录linux系统,然后使用su -就可以切换成root身份,前提是知道root的密码。

Last login: Wed Sep  5 22:22:05 2018
[test@localhost ~]$ su -
Password: 
Last login: Wed Sep  5 22:23:20 CST 2018 on pts/0
[root@localhost ~]# 

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

[root@localhost ~]# echo $LOGNAME
root
[root@localhost ~]# su - test
Last login: Wed Sep  5 22:24:37 CST 2018 from 10.0.30.1 on pts/0
[test@localhost ~]$ echo $LOGNAME
test
[test@localhost ~]$ 

  su的语法为:su [-] username

  后面可以跟“-”也可以不跟,普通用户su不加username时就是切换到root用户,当前root用户同样可以su到普通用户。

  加“-”后会连同用户的环境变量一起切换过来。su test后虽然切换到了test用户,但是当前目录还是切换前的/root目录,然后当用su - test时切换用户后则到了test的家目录/home/test。当用root切换普通用户时,是不需要输入密码的。这也体现了root用户至高无上的权利。

  用su是可以切换用户身份,如果每个普通用户都能切换到root身份,如果某个用户不小心泄露了root的密码,那岂不是系统非常的不安全?没有错,为了改进这个问题,产生了sudo这个命令。使用sudo执行一个root才能执行的命令是可以办到的,但是需要输入密码,这个密码并不是root的密码而是用户自己的密码,默认只有root用户能使用sudo命令,普通用户想要使用sudo,则需要root预先设定的,即,使用visudo命令去相关的配置文件/etc/sudoers,如果没有visudo这个命令,请先会用yum install -y sudo安装。

root    ALL=(ALL)       ALL
test    ALL=(ALL)       ALL

  默认root能够sudo是因为这个文件中有一行“root ALL=(ALL) ALL”,在该行下面加入“test ALL=(ALL) ALL”,就可以让test用户拥有sudo的权利。如果没增加一个用户就设置一行,这样太麻烦了,所以你可以这样设置。

## Allows people in group wheel to run all commands
%wheel  ALL=(ALL)       ALL

  把这一行前面的“#”去掉,这一行生效。它的意思是,wheel这个组下面的所有用户拥有了sudo的权限。

[root@localhost ~]# su test
[test@localhost root]$ touch 1.txt
touch: cannot touch 鈥.txt鈥 Permission denied
[test@localhost root]$ sudo touch 1.txt

We trust you have received the usual lecture from the local System
Administrator. It usually boils down to these three things:

    #1) Respect the privacy of others.
    #2) Think before you type.
    #3) With great power comes great responsibility.

[sudo] password for test: 
[test@localhost root]$ ls -l 1.txt
ls: cannot access 1.txt: Permission denied
[test@localhost root]$ sudo ls -l 1.txt
-rw-r--r--. 1 root root 0 Sep  5 22:51 1.txt
[test@localhost root]$ 

  

识/etc/passwd和/etc/shadow这两个文件可以说是linux系统中最重要的文件之一。如果没有这两个文件或者这两个文件出问题,则你是无法正常登录linux系统的。[root@local
一、用户用户组管理1新增组groupadd命令格式:groupadd组名2删除组groupdel格式:groupdel组名3增加用用户命令useradd格式:useradd用户名u:表示自定义U
1基础知识Linux作为一种多用户的操作系统(服务器系统),允许多个用户同时登陆到系统上,并响应每个用户的请求。任何需要使用操作系统的用户,都需要一个系统账号,账号分为:管理员账号与普通用户账号。在L
Linux是个多用户多任务的分时操作系统,所有一个要使用系统资源的用户都必须先向系统管理员申请一个账号,然后以这个账号的身份进入系统用户的账号一方面能帮助系统管理员对使用系统用户进行跟踪,并控制
Linux是一个多用户多任务的分是操作系统,用户是实现操作系统资源分配,同时也是安全权限模型的核心要素之一;用户组是一个容纳很多用户的容器,可以分配权限组,进一步优化了权限分配。一、用户管理用户管理
一,组操作1创建组groupaddtest增加一个test组2修改组groupmodntest2test将test组的名子改成test23删除组groupdeltest2删除组test24查看组41查
用户用户组管理linux只认识UID和GID可在/etc/passwd和/etc/group中找到/etc/passwd详解[root@lgh2~]cat/etc/passwdroot:x:0:0
章目录用户配置文件用户信息文件/etc/passwd影子文件/etc/shadow组信息文件/etc/group和组密码文件/etc/gshadow/etc/group/etc/gshadow用户
Linux系统是一个多用户多任务的分时操作系统,任何一个要使用系统用户,都必须拥有自己的账号。实现用户管理,主要做:用户账号的添加、删除、修改;用户口令的管理用户组管理。(一)用户管理(1
目录一、用户账号的管理1、添加新的用户账号使用useradd命令,其语法如下:2、删除帐号3、修改帐号4、用户口令的管理二、用户组管理1、增加一个新的用户组使用groupadd命令。其格式如下:2