当前位置: 首页 > 科技观察

列出Linux系统所有用户的3种方法

时间:2023-03-19 13:50:15 科技观察

通过使用/etc/passwd文件、getent命令、compgen命令查看系统中用户的信息。众所周知,Linux系统中的用户信息保存在/etc/passwd文件中。这是一个包含每个用户基本信息的文本文件。当我们在系统中创建用户时,新用户的详细信息将添加到此文件中。/etc/passwd文件在文件中以一行的形式记录了每个用户的基本信息,一行包含7个字段。/etc/passwd文件中的一行代表一个用户。该文件将用户信息分为3个部分。*Part1:`root`用户信息*Part2:系统定义的账户信息*Part3:真实用户的账户信息***Part是root账户,代表管理员账户,可以访问各个方面系统都拥有全能。第二部分是正确安装和更新系统软件所需的系统定义组和帐户。第三部分在***,代表使用系统的真实用户。创建新用户时,会修改以下4个文件。*`/etc/passwd`:用户帐户详细信息在此文件中更新。*`/etc/shadow`:用户帐户密码在此文件中更新。*`/etc/group`:新用户组的详细信息在此文件中更新。*`/etc/gshadow`:新用户组密码在此文件中更新。**推荐阅读:**如何在Linux上查看用户的创建日期文件操作命令,如cat、more、less等,以打印在Linux系统上创建的用户列表。/etc/passwd是一个文本文件,其中包含登录Linux系统所需的每个用户信息。它包含有关用户的有用信息,例如用户名、密码、用户ID、组ID、用户ID信息、用户的主目录和shell。/etc/passwd文件将每个用户的详细信息写成一行,包含七个字段,每个字段用冒号分隔::#cat/etc/passwdroot:x:0:0:root:/root:/bin/bashbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologinadm:x:3:4:adm:/var/adm:/sbin/nologinlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinsync:x:5:0:sync:/sbin:/bin/syncshutdown:x:6:0:shutdown:/sbin:/sbin/shutdownhalt:x:7:0:halt:/sbin:/sbin/haltmail:x:8:12:mail:/var/spool/mail:/sbin/nologinftp:x:14:50:FTP用户:/var/ftp:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologinsshd:x:74:74:Privilege-separatedSSH:/var/empty/sshd:/sbin/nologintcpdump:x:72:72::/:/sbin/nologin2gadmin:x:500:10::/home/viaadmin:/bin/bashapache:x:48:48:Apache:/var/www:/sbin/nologinzabbix:x:498:499:zabbix监控系统:/var/lib/zabbix:/sbin/nologinmysql:x:497:502::/home/mysql:/bin/bashzend:x:502:503::/u01/zend/zend/gui/lighttpd:/sbin/nologinrpc:x:32:32:Rpcbind守护进程:/var/cache/rpcbind:/sbin/nologin2daygeek:x:503:504::/home/2daygeek:/bin/bashnamed:x:25:25:Named:/var/named:/sbin/nologinmageshm:x:506:507:2gAdmin-MageshM:/home/mageshm:/bin/bash7个字段的详细信息如下Username(magesh):创建的用户用户名,字符长度为1到12个字符。密码(x):加密后的密码保存在`/etc/shadow文件中。**UserID(506):表示用户的ID号,每个用户必须有唯一的ID。UID号0为root用户保留,UID号1~99为系统用户保留,UID号100~999为系统账户和组保留。**GroupID(507):表示该组的ID号。每个组必须有一个唯一的GID,它存储在/etc/group文件中。**用户信息(2gAdmin-MageshM):表示描述字段,可以用来描述用户的信息(LCTT译注:此处原文存疑)。**主目录(/home/mageshm):代表用户的主目录。**Shell(/bin/bash):表示用户使用的shell类型。您可以使用awk或cut命令仅打印出Linux系统中所有用户的用户名列表。显示的结果是一样的。#awk-F':''{print$1}'/etc/passwdor#cut-d:-f1/etc/passwdrootbindaemonadmlpsyncshutdownhaltmailftppostfixsshdtcpdump2gadminapachezabbixmysqlzendrpc2daygeeknamedmageshm方法二:使用getent命令显示NameServiceSwitch库支持的数据库。这些库的配置文件是/etc/nsswitch.conf。getent命令显示类似于/etc/passwd文件的用户详细信息,它将每个用户详细信息显示为包含七个字段的一行。#getentpasswdroot:x:0:0:root:/root:/bin/bashbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologinadm:x:3:4:adm:/var/adm:/sbin/nologinlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinsync:x:5:0:sync:/sbin:/bin/syncshutdown:x:6:0:shutdown:/sbin:/sbin/shutdownhalt:x:7:0:halt:/sbin:/sbin/haltmail:x:8:12:mail:/var/spool/mail:/sbin/nologinftp:x:14:50:FTP用户:/var/ftp:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologinsshd:x:74:74:权限分离SSH:/var/empty/sshd:/sbin/nologintcpdump:x:72:72::/:/sbin/nologin2gadmin:x:500:10::/home/viadmin:/bin/bashapache:x:48:48:Apache:/var/www:/sbin/nologinzabbix:x:498:499:Zabbix监控系统:/var/lib/zabbix:/sbin/nologinmysql:x:497:502::/home/mysql:/bin/bashzend:x:502:503::/u01/zend/zend/gui/lighttpd:/sbin/nologinrpc:x:32:32:Rpcbind守护进程:/var/cache/rpcbind:/sbin/nologin2daygeek:x:503:504::/home/2daygeek:/bin/bashnamed:x:25:25:Named:/var/named:/sbin/nologinmageshm:x:506:507:2gAdmin-mageshM:/home/mageshm:/bin/bash7个字段的详细信息如上(LCTT译注:此处重复内容,略)也可以使用awk或cut命令只打印所有用户Linux系统名称列表中的用户。显示的结果是一样的。方法3:使用compgen命令compgen是一个bash内置命令,它将显示所有可用的命令、别名和函数。#compgen-urootbindaemonadmlpsyncshutdownhaltmailftppostfixsshdtcpdump2gadminapachezabbixmysqlzendrpc2daygeeknamedmageshm