linux用户和组

linux用户和用户组

Linux 是多用户多任务操作系统,换句话说,Linux 系统支持多个用户在同一时间内登陆,不同用户可以执行不同的任务,并且互不影响。
用户组是具有相同特征用户的逻辑集合。简单的理解,有时我们需要让多个用户具有相同的权限,比如查看、修改某一个文件的权限,一种方法是分别对多个用户进行文件访问授权,如果有 10 个用户的话,就需要授权 10 次,那如果有 100、1000 甚至更多的用户呢?
最好的方式是建立一个组,让这个组具有查看、修改此文件的权限,然后将所有需要访问此文件的用户放入这个组中。那么,所有用户就具有了和组一样的权限,这就是用户组。
将用户分组是 Linux 系统中对用户进行管理及控制访问权限的一种手段,通过定义用户组,很多程序上简化了对用户的管理工作。

Linux用户和组的关系

用户和用户组的对应关系有以下 4 种:

  1. 一对一:一个用户可以存在一个组中,是组中的唯一成员;
  2. 一对多:一个用户可以存在多个用户组中,此用户具有这多个组的共同权限;
  3. 多对一:多个用户可以存在一个组中,这些用户具有和组相同的权限;
  4. 多对多:多个用户可以存在多个组中,也就是以上 3 种关系的扩展。
    linux用户和组_第1张图片
    实验流程把用户加入组
  5. 一对一
[root@localhost ~]#useradd test1 
#添加用户时会自动建立和用户名相同的组作为此用户的初始组
[root@localhost ~]# cat /etc/passwd 
#查看组GID号
[root@localhost ~]# cat /etc/group
#查看用户是否则这个GID号里
  1. 一对多:
[root@localhost ~]#groupadd group1
#创建新群组 group1
[root@localhost ~]#gpasswd -a test1 group1
# 将test1 用户加入到群组group1中

7 多对一:

[root@localhost ~]#useradd test2 -g group1
#创建用户test2的同时加入主要组group1
[root@localhost ~]#useradd test3 -g group1
#创建用户test3的同时加入主要组group1

8 多对多:

[root@localhost ~]#gpasswd -a test2 test1
## 将test2 用户加入到群组test1
[root@localhost ~]#gpasswd -a test3 test1
## 将test3 用户加入到群组test1

补(关于gpasswd和groupaad命令解释):

gpasswd命令

-A:#将peter(用户)设为test组的管理员

[root@localhost ~]# gpasswd -A peter test

-a:#将用户peter加入到test组


[root@localhost ~]# gpasswd -a peter test  

-d: #将用户peter从test组中移出

[root@localhost ~]# gpasswd -d peter test 

-M:#将ye2,ye3,ye4用户添加到group组中来(将多用户添加到组)

 gpasswd -M ye2,ye3,ye4 group #将ye2,ye3,ye4用户添加到group组中来
添加一个用户组,并指定GID

groupadd

-g:指定组号创建组

[root@Blackghost ~] groupadd -g 444 test

你可能感兴趣的:(linux用户和组)