Linux用户系统中的群组与群组管理员讲解

   关于群组: 有效与初始群组、groups, newgrp

  代码如下:

  # /etc/group

  这个档案就是在记录 GID 与群组名称的对应了~我的 /etc/group 内容有点像这样:

  代码如下:

  root:x:0:root

  bin:x:1:root,bin,daemon

  daemon:x:2:root,bin,daemon

  sys:x:3:root,bin,adm

  也是以冒号‘:’作为栏位的分隔符号,共分为四栏,每一栏位的意义是:

  1. 群组名称:就是群组名称啦!

  2. 群组密码:通常不需要设定,因为我们很少使用到群组登入! 不过,同样的,密码也是被纪录在 /etc/gshadow 当中啰!

  3. GID:就是群组的 ID 啊~

  4. 支援的帐号名称:加入这个群组里面的所有的帐号, 我们知道,一个使用者是可以加入多个群组的。举例来说,如果我想要让 dmtsai 也加入 root 这个群组,那么在第一行的最后面加上‘,dmtsai’,注意不要有空格, 使成为‘ root:x:0:root,dmtsai’就可以啰~

  比较重要的特色在于第四栏啦,因为每个使用者都可以拥有多个支援的群组, 这就好比在学校念书的时候,我们可以加入多个社团一样! ^_^。 不过这里您或许会觉得奇怪的,那就是:‘假如我同时加入多个群组, 那么我在作业的时候,到底是以那个群组为准?’底下我们就来谈一谈这个‘有效群组’的概念。

  # 有效群组(effective group)与初始群组(initial group)

  还记得每个使用者在他的 /etc/passwd 里面的第四栏有所谓的 GID 吧?那个 GID 就是所谓的‘初始群组 ( initial group ) ’了!也就是说,当使用者一登入系统,立刻就拥有这个群组的相关权限的意思。 举例来说,我们上面提到 dmtsai 这个使用者的 /etc/passwd 与 /etc/group 还有 /etc/gshadow 相关的内容如下:

  代码如下:

  [root@linux ~]# grep dmtsai /etc/passwd /etc/group /etc/gshadow

  /etc/passwd:dmtsai:x:501:501::/home/dmtsai:/bin/bash

  /etc/group:users:x:100:dmtsai

  /etc/group:dmtsai:x:501:

  /etc/gshadow:users:::dmtsai

  /etc/gshadow:dmtsai:!::

  仔细看到上面这个表格,在 /etc/passwd 里面,dmtsai 这个使用者所属的群组为 GID=501 , 也就是 /etc/group 里头 dmtsai 那个群组啦~因为这是 initial group ,所以, 使用者一登入就会主动取得,不需要在 /etc/group 的第四个栏位写入该帐号的!

  但是非 initial group 的其他群组可就不同了。举上面这个例子来说,我将 dmtsai 加入 users 这个群组当中,由于 users 这个群组并非是 dmtsai 的初始群组,因此, 我必须要在 /etc/group 这个档案中,找到 users 那一行,并且将 dmtsai 这个帐号加入第四栏, 这样 dmtsai 才能够支援 users 这个群组啊。

  那么在这个例子当中,因为我的 dmtsai 这个帐号同时支援 dmtsai 与 users 这两个群组, 因此,在读取/写入/执行档案时,针对群组部分,只要是 users 与 dmtsai 这两个群组拥有的功能, 我 dmtsai 这个使用者都能够拥有喔!这样瞭呼?不过,这是针对已经存在的档案而言, 如果今天我要建立一个新的档案或者是新的目录,请问一下,新档案的群组是 dmtsai 还是 users ? 呵呵!这就得要检查一下当时的有效群组了 (effective group)。

  如果我以 dmtsai 这个使用者的身份登入后,该如何知道我所有支援的群组呢? 很简单啊,直接输入 groups 就可以了!注意喔,是 groups 有加 s 呢!结果像这样:

  代码如下:

  [dmtsai@linux ~]$ groups

  dmtsai users

  在这个输出的讯息中,我知道我同时属于 dmtsai 及 users 这个两个群组,而且, 第一个输出的群组即为有效群组 (effective group) 了。 也就是说,我的有效群组为 dmtsai 啦~此时,如果我以 touch 去建立一个新档,例如: touch test ,那么这个档案的拥有者为 dmtsai ,而且群组也是 dmtsai 的啦。 这样是否可以瞭解什么是有效群组了?

  那么如何变更有效群组呢?这个有两个方法,不论是那个方法,都是以 newgrp 达成的! 以上面这个例子来说,因为我的 dmtsai 使用者同时拥有 dmtsai 与 users 两个群组,因此, dmtsai 当然可以随时切换 dmtsai/users 成为有效群组啰。所以,我可以下达:

  代码如下:

  [dmtsai@linux ~]$ newgrp users

  [dmtsai@linux ~]$ groups

  users dmtsai

  此时,我的有效群组就成为 users 了。当然,要能够顺利切换有效群组的话,还需要 /etc/gshadow 的辅助才行~这个等一下我们会说明的。好了,那么如果你开始在 /home/dmtsai 这个家目录底下尝试建立一个档案,例如‘ touch test2 ’好了,会发生什么状态呢? 呵呵!那个档案的群组竟然变成 users 了!这样更清楚有效群组的意义了吧?!

  我们额外的来讨论一下 newgrp 这个指令,这个指令可以变更目前使用者的有效群组, 而且是另外以一个 shell 来提供登入的喔,所以,以上面的例子来说, dmtsai 这个使用者目前是以另一个 shell 登入的,而且新的 shell 给予 dmtsai 有效 GID 为 users 就是了。当直接执行‘ newgrp groupname ’时,使用者的有效群组会成为 groupname , 此时虽然使用者的环境设定(例如环境变数等等其他资料)不会有影响,但是使用者的‘权限’将会重新被计算。 举例来说, dmtsai 此时建立的新档案群组是 users 了~

  鸟哥的这个例子当中,要注意的是, dmtsai 这个使用者本来就属于 users 与 dmtsai 这两个群组, 所以他可以直接使用 newgrp 来切换有效群组,而要离开新的有效群组时,输入‘ exit ’即可。 假设我的 Linux 系统当中还有另一个群组,名称为 vbird,那么 dmtsai 是否可以登入 vbird 这个群组? 在某些前提下是可以的:

  * vbird 这个群组在 /etc/gshadow 的密码栏为合法的(不具有 ! 开头!);

  * dmtsai 必须让 root 或群组管理员 (group administrator) 加入到 vbird 群组中。

  这两个大前提缺一不可喔!好了,假设我已经使用 gpasswd 建立了 vbird 这个群组的密码, 而 dmtsai 也被加入群组成员当中了,那么当 dmtsai 输入 ‘newgrp vbird’时, 嘿嘿! dmtsai 这个使用者的有效群组就能够变成 vbird 啰~

  # /etc/gshadow

  刚刚讲了很多关于‘有效群组’的概念,另外,也提到 newgrp 这个指令的用法, 但是,如果 /etc/gshadow 这个设定没有搞懂得话,那么 newgrp 是无法动作的呢! 我的 /etc/gshadow 的内容有点像这样:

  代码如下:

  root:::root

  bin:::root,bin,daemon

  daemon:::root,bin,daemon

  sys:::root,bin,adm

  同样还是使用冒号‘:’来作为栏位的分隔字元,而且你会发现,这个档案几乎与 /etc/group 一模一样啊!是这样没错~不过,要注意的大概就是第二个栏位吧~第二个栏位是密码栏, 如果密码栏上面是‘!’时,表示该群组不能使用密码来登入呢! 至于第四个栏位也就是支援的帐号名称啰~

  1. 群组名称

  2. 密码栏,同样的,开头为 ! 表示无法登入;

  3. 群组管理员的帐号 (相关资讯在后续介绍)

  4. 该群组的所属帐号 (与 /etc/group 内容相同!)

  不过,就以系统的操作来说,事实上,这个 /etc/gshadow 的密码提供,最大的功能是在于‘ 让那些不在群组中的成员,临时加入该群组用的。 ’ 实际上使用的情况是很少的~而如果真的要操作这样的环境,那就得要熟悉 newgrp 的用法啰! 而且还要提供某个群组的密码出来,真是不好管理。所以,若真的想要让某个使用者利用该群组的功能时, 还是直接将对方加入群组的支援就好了!省得麻烦~

  Linux群组管理员

  为什么需要群组管理员

  我们假设一个场景,一个公司里有好多部门,不同员工需要加入到不同的群组。如果其中一个部门增加员工,就需要通知管理员,将其加入到对应的群组。如果每个部门都要增加员工,那管理员可能每天都会疲于奔命处理各个请求。

  这时我们可以针对每个群组设置组长,并允许组长添加删除组成员,这样不仅可以提高效率,还减少了管理员的工作。

  如何指派群组管理

  语法:

  代码如下:

  gpasswd -A USERNAME GROUPNAME

  效果:


  在添加群组管理时,可以指定多个用户,多个用户之间需要使用英文逗号隔开。

  如何删除群组管理

  语法:

  复制代码

  代码如下:

  gpasswd -A "" GROUPNAME

  效果:


  gpasswd没有特定的参数用于删除群组管理,我们指定空字符串即可。如果组内有多个管理员,指定保留用户即可。

  群组管理添加成员

  语法:

  复制代码

  代码如下:

  gpasswd -a USERNAME GROUPNAME

  效果:


  群组管理删除成员

  语法:

  复制代码

  代码如下:

  gpasswd -d USERNAME GROUPNAME

  效果:

时间: 2024-09-14 07:53:53

Linux用户系统中的群组与群组管理员讲解的相关文章

如何在 Linux/Unix 系统中验证端口是否打开

在 Linux 或者类 Unix 中,我该如何检查某个端口是否被占用?我又该如何验证 Linux 服务器中有哪些端口处于监听状态? 验证哪些端口在服务器的网络接口上处于监听状态是非常重要的.你需要注意那些开放端口来检测网络入侵.除了网络入侵,为了排除故障,确认服务器上的某个端口是否被其他应用程序占用也是必要的.比方说,你可能会在同一个系统中安装了 Apache 和 Nginx 服务器,所以了解是 Apache 还是 Nginx 占用了 # 80/443 TCP 端口真的很重要.这篇快速教程会介绍

linux服务器系统中手动配置lamp服务器的经验分享_Linux

LAMP是Linux.Apache.MySQL.PHP/Perl/Python的简称.它所组成的各组件都是开源软件,因此很方便自由的获取,导致这些组件的广泛使用,并不断完善发展,初步形成新的软件系统格局,并可能成为开源软件系统工程化的核心模式. 要安装比较新的httpd我们就必须安装比较新的apr.红帽6上就不需要再指定安装apr了,因为它默认安装的版本比较新.但是我们这里使用的是红帽5.8的版本,它给我们安装的apr版本有点老,我们要安装新版本的apr,是不是老版本的apr就要卸载了呢?这不是

Linux系统中强大的文本操作命令tr的使用讲解

  tr 转换,压缩,截短,删除字符 tr [option].....set1 [set2] 参数: -d,--delete 删除字符串1中的字符,不进行转换. -s,--squeeze-repeats 将重复出现字符串压缩为一个字符串. -t,--truncate-set1 将字符串1的长度截成字符串2的长度. -c,--complement 取字符串1的补集.要求字符集为ASCII. --help 打印帮助. --version 显示版主信息. 转义字符如下: NNN 字符的八进制码 反斜线

Linux桌面系统的优势

当我放弃 Windows 转而使用 Linux 系统 后,我的信心不断增长.出于安全方面的考虑促使我选用 Linux 系统,但是我很快发现了很多使用 Linux 桌面系统的优势. 对于那些还对 Linux 系统犹豫不决,或是那些不甚了解 Linux 系统的用户,我将通过这篇文章给大家介绍一些使用 Linux 桌面系统的优势. 免费才是王道 首先, Linux 系统完全免费.你无须为使用的操作系统或软件花费一分钱.除了免费获取软件产生的经济效益之外,你还可以在 Linux 系统中随意使用一些当前很

Linux用户仍然无法完成的七项任务

作为一位Linux用户群体中的铁杆成员,我有时候不得不--虽然很不情愿--承认,使用 Mac OS X或者Windows确实能让我实现很多在Linux平台上根本无法完成的任务.这些任务无法达成跟Linux这款平台自身的局限性完全无关.这一问题同 时也困扰着软件开发人员与内容供应商们. 没你的份儿,Linux用户. 更新说明:2015年5月4日,第五张幻灯片内的参考内容Amazon Prime被移除.事实上,在安装额外插件之外.Amazon Prime已经能够正常运行在Linux环境当中. 我刚开

linux/windows系统如何安装php-gd扩展库

昨天有位客户咨询我一个问题,他在使用然之OA 系统时涉及到图片显示时提示下面错误窗口.看到这个错误提示,我们肯定都会想到是不是PHP的gd库未安装,但是这位朋友说他用phpinfo查看了下PHP环境,发现gd扩展已存在,而且问题依旧存在,所以才头疼问题出在哪里.下面是这位朋友给我的截图: 看到这里,可能一些细心的朋友已经发现问题所在了,很明显,这位用户的gd扩展安装得不完整.这里我先直接给大家展示gd库完整安装后的截图: 所以我们在检查PHP环境,要看一下扩展是否安装齐全.完整,针对上面的问题,

如何在win8系统中获取删除文件的最高权限?

  在以前的winXP系统和win7 64位旗舰版系统中,咱们默认使用的就是管理员账户登陆,因此咱们在操作Windows系统的时候遇到权限的问题也比较少,但是在进入到win8系统之后,为了更好的保护用户的隐私,Windows系统默认了不再使用管理员账户登陆,因此,咱们在进行一些操作的时候,就会收到诸如权限不足的提示,那么遇到这样的情况咱们要如何处理呢?今天,小编就来具体介绍一下,如何在win8系统中获取删除文件的最高权限? 1.首先,咱们需要返回到win8系统的传统桌面位置,然后在win8系统中

Windows 7系统中体验丰富BitLocker安全性功能

&http://www.aliyun.com/zixun/aggregation/37954.html">nbsp;   BitLocker 可通过对 Windows 和您的数据所驻留在的整个驱动器进行加密来帮助保护包括文档和密码在内的一切信息的安全.启用 BitLocker 后,它会自动对该驱动器上保存的所有文件进行加密. 在Windows 7(旗舰版)中BitLocker的功能也有了更多改进,BitLocker To Go 就是 Windows 7 的一项新功能,它可以对U盘及

linux-关于Linux SUSE 系统的shell问题

问题描述 关于Linux SUSE 系统的shell问题 linux suse 系统中,默认的shell是bc的,怎么把默认的shell,更改回到以前的shell 解决方案 硬盘安装SUSE Linux10系统(摘) 解决方案二: cat /etc/passwd root:0:0:root:/root:/bin/bash 红色部分替换为你任何想要的shell 解决方案三: 现在有一个现象,Linux SUSE 重新启动之后,启动之后就进入了bc,也不能退出,退出的话直接就退出了系统,在进入的话,