Linux下查明用户属于哪个组的5种方法

Linux下查明用户属于哪个组的5种方法

这个重要的命令可以帮助你识别Linux系统上的现有组。

这些命令可帮助你识别用户属于哪些组。

/etc/passwd文件中列出了所有系统用户,/etc/group文件中列出了组,实际的密码存储在/etc/shadow文件中。无论我们使用什么命令,它都会从这些文件获取信息。

而且,每个命令有其独特的功能,使用户仅能获得他们所需的信息。

Linux中有两种类型的组:

  • 主要组:主要组是与用户帐户关联的主要组。每个用户势必是单个主要组的成员。
  • 次要组:次要组用于向用户授予额外权限。每个用户可以成为多个次要组的成员。

什么是/etc/passwd文件?

“/etc/passwd”是个文本文件,包含登录到Linux系统所需的每个用户信息。它维护有关用户的有用信息,比如用户名、密码、用户ID、组ID、用户信息、主目录和shell。

如上所述,密码文件中的每个用户配置文件都是一行,含有七个字段。

$ grep "daygeek" /etc/passwd  

daygeek:x:1000:1000:daygeek,,,:/home/daygeek:/bin/bash 

什么是/etc/grou文件?

“/etc/group”是个文本文件,定义了用户属于哪些组。我们可以将多个用户添加到同一个组。

Linux权限组织成用户、组及其他三类,这使用户可以访问其他用户的文件和文件夹。

它维护有关组的有用信息,比如组名称、组密码、组ID(GIT)和成员列表。如上所述,组文件中的每个组详细信息都是一行,含有四个字段。

你可以使用以下七个命令来执行此操作。

groups:显示组的所有成员。

id:打印出指定用户名的用户和组信息。

lid或libuser-lid:显示用户的组或组的用户。

getent:从Name Service Switc获取条目。

compgen:compgen是bash内置命令,会为用户显示所有的可用命令。

members:列出组的成员。

/etc/group file:另外,我们可以从/etc/group文件查看相应用户的组。

方法1:如何使用groups命令找出Linux中用户属于哪些组?

groups命令打印出特定用户名的主要组及子组的名称。

$ groups daygeek  

daygeek : daygeek adm cdrom sudo dip plugdev lpadmin sambashare 

如果你想检查与当前用户关联的组列,只需运行不带任何用户名的“groups”命令。

$ groups  

daygeek adm cdrom sudo dip plugdev lpadmin sambashare 

方法2:如何使用id命令找出Linux中用户属于哪些组?

id命令代表身份。它打印真实有效的用户、组和补充性的组信息,比如用户名、UID、组名称和GUID。

$ id daygeek  

uid=1000(daygeek) gid=1000(daygeek) groups=1000(daygeek),4(adm),24(cdrom),27(sudo),30(dip),46(plugdev),118(lpadmin),128(sambashare) 

如果你想检查与当前用户关联的组列表,只需运行不带任何用户名的“id”命令。

$ id  

uid=1000(daygeek) gid=1000(daygeek) groups=1000(daygeek),4(adm),24(cdrom),27(sudo),30(dip),46(plugdev),118(lpadmin),128(sambashare) 

方法3:如何使用lid命令找出Linux中用户属于哪些组?

lid或libuser-lid命令显示了有关组的信息,包含用户名或组名称中所含的用户。该命令需要sudo权限。

你应该在较新的系统上运行libuser-lid命令而不是lid命令。

$ sudo libuser-lid daygeek  


adm(gid=4)  


cdrom(gid=24)  


sudo(gid=27)  


dip(gid=30)  


plugdev(gid=46)  


lpadmin(gid=116)  


daygeek(gid=1000)  

sambashare(gid=126) 

方法4:如何使用getent命令找出Linux中用户属于哪些组?

getent命令显示了Name Service Switch库支持的数据库的条目,这在/etc/nsswitch.conf中已有配置。

$ getent group | grep daygeek  


adm:x:4:syslog,daygeek  


cdrom:x:24:daygeek  


sudo:x:27:daygeek,2gadmin  


dip:x:30:daygeek  


plugdev:x:46:daygeek  


lpadmin:x:116:daygeek  


daygeek:x:1000:  

sambashare:x:126:daygeek 

如果你只想打印出特定用户的相关组的名称,请使用awk命令以及上述命令。

$ getent group | grep daygeek | awk -F: '{print $1}'  


adm  


cdrom  


sudo  


dip  


plugdev  


lpadmin  


daygeek  

sambashare 

运行以下命令,只打印出主要组的信息。

$ getent group daygeek  

daygeek:x:1000: 

方法5:如何使用/etc/group文件找出Linux下用户属于哪些组?

使用grep命令,你可以从/etc/group文件轻松打印出有关某个用户的相关组的信息。

grep命令是指“全局正则表达式打印”,它从文件打印出匹配格式。

$ grep daygeek /etc/group  


adm:x:4:syslog,daygeek  


cdrom:x:24:daygeek  


sudo:x:27:daygeek,2gadmin  


dip:x:30:daygeek  


plugdev:x:46:daygeek  


lpadmin:x:116:daygeek  


daygeek:x:1000:  

sambashare:x:126:daygeek 

如果你只想打印出某个用户的相关组的名称,请使用awk命令以及上述命令。

$ grep daygeek /etc/group | awk -F: '{print $1}'  


adm  


cdrom  


sudo  


dip  


plugdev  


lpadmin  


daygeek  

sambashare 

方法6:如何使用Bash脚本找出Linux下用户属于哪些组?

你可以使用简单的bash脚本来做到这一点。

$ for user in $(cut -d":" -f1 /etc/passwd); do groups $user; done  


root : root  


daemon : daemon  


www-data : www-data nagcmd  


saned : saned scanner  


pulse : pulse audio  


avahi : avahi  


colord : colord  


hplip : lp  


geoclue : geoclue  


gnome-initial-setup : nogroup  


gdm : gdm  


daygeek : daygeek adm cdrom sudo dip plugdev lpadmin sambashare  


sshd : nogroup  


thanu : thanu  


renu : renu  


2gadmin : 2gadmin sudo  


testuser : testuser  


demouser : demouser  


sudha : sudha  


suresh : suresh  


mysql : mysql  


ntp : ntp  


u1 : u1  


u2 : u2  


u3 : u3  


u4 : u4  


u5 : u5  

nagios : nagios nagcmd 

针对特定的用户使用下列脚本。

$ for user in daygeek 2gadmin; do groups $user; done  


daygeek : daygeek adm cdrom sudo dip plugdev lpadmin sambashare  

2gadmin : 2gadmin sudo 

另外的补充方法1:如何使用compgen命令找出Linux下的所有组?

compgen是一个bash内置命令,显示了Linux系统下的所有组。

$ compgen -g  


root  


daemon  


bin  


sys  


adm  


tty  


disk  


lp  


mail  


news  


uucp  


.  


.  


gdm  


daygeek  


sambashare  


thanu  


renu  


2gadmin  


testuser  


demouser  


sudha  


suresh  


admin  


u1  


u2  


u3  


u4  


u5  


nagios  

nagcmd 

另外的补充方法2:如何使用member命令列出Linux下的组成员?

member命令让你可以列出Linux下一个组的成员。

相关推荐