通過使用/etc/passwd 文件,getent命令,compgen命令這三種方法查看系統中用戶的信息。 Linux 系統中用戶信息存放在/etc/passwd文件中。 這是一個包含每個用戶基本信息的文本文件。當我們在系統中創建一個用戶,新用戶的詳細信息就會被添加到這個文件中。 /etc/pass ...
通過使用/etc/passwd
文件,getent
命令,compgen
命令這三種方法查看系統中用戶的信息。
Linux 系統中用戶信息存放在/etc/passwd
文件中。
這是一個包含每個用戶基本信息的文本文件。當我們在系統中創建一個用戶,新用戶的詳細信息就會被添加到這個文件中。
/etc/passwd
文件將每個用戶的基本信息記錄為文件中的一行,一行中包含 7 個欄位。
/etc/passwd
文件的一行代表一個單獨的用戶。該文件將用戶的信息分為 3 個部分。
* 第 1 部分:`root` 用戶信息 * 第 2 部分:系統定義的賬號信息 * 第 3 部分:真實用戶的賬戶信息
第一部分是 root 賬戶,這代表管理員賬戶,對系統的每個方面都有完全的權力。
第二部分是系統定義的群組和賬戶,這些群組和賬號是正確安裝和更新系統軟體所必需的。
第三部分在最後,代表一個使用系統的真實用戶。
在創建新用戶時,將修改以下 4 個文件。
* `/etc/passwd`: 用戶賬戶的詳細信息在此文件中更新。 * `/etc/shadow`: 用戶賬戶密碼在此文件中更新。 * `/etc/group`: 新用戶群組的詳細信息在此文件中更新。 * `/etc/gshadow`: 新用戶群組密碼在此文件中更新。
方法 1 :使用 /etc/passwd 文件
使用任何一個像cat
、more
、less
等文件操作命令來列印 Linux 系統上創建的用戶列表。
/etc/passwd
是一個文本文件,其中包含了登錄 Linux 系統所必需的每個用戶的信息。它保存用戶的有用信息,如用戶名、密碼、用戶 ID、群組 ID、用戶 ID 信息、用戶的家目錄和 Shell 。
/etc/passwd
文件將每個用戶的詳細信息寫為一行,其中包含七個欄位,每個欄位之間用冒號 : 分隔:
# cat /etc/passwd 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 ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin postfix:x:89:89::/var/spool/postfix:/sbin/nologin sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin tcpdump:x:72:72::/:/sbin/nologin 2gadmin:x:500:10::/home/viadmin:/bin/bash apache:x:48:48:Apache:/var/www:/sbin/nologin zabbix:x:498:499:Zabbix Monitoring System:/var/lib/zabbix:/sbin/nologin mysql:x:497:502::/home/mysql:/bin/bash zend:x:502:503::/u01/zend/zend/gui/lighttpd:/sbin/nologin rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin 2daygeek:x:503:504::/home/2daygeek:/bin/bash named:x:25:25:Named:/var/named:/sbin/nologin mageshm:x:506:507:2g Admin - Magesh M:/home/mageshm:/bin/bash
7 個欄位的詳細信息如下。
**用戶名 (magesh): 已創建用戶的用戶名,字元長度 1 個到 12 個字元。 **密碼(x):代表加密密碼保存在 `/etc/shadow 文件中。 **用戶 ID(506):代表用戶的 ID 號,每個用戶都要有一個唯一的 ID 。UID 號為 0 的是為 root 用戶保留的,UID 號 1 到 99 是為系統用戶保留的,UID 號 100-999 是為系統賬戶和群組保留的。 **群組 ID (507):代表群組的 ID 號,每個群組都要有一個唯一的 GID ,保存在 /etc/group文件中。 **用戶信息(2g Admin - Magesh M):代表描述欄位,可以用來描述用戶的信息(LCTT 譯註:此處原文疑有誤)。 **家目錄(/home/mageshm):代表用戶的家目錄。 **Shell(/bin/bash):代表用戶使用的 shell 類型。
你可以使用 awk 或 cut 命令僅列印出 Linux 系統中所有用戶的用戶名列表。顯示的結果是相同的。
# awk -F':' '{ print $1}' /etc/passwd or # cut -d: -f1 /etc/passwd root bin daemon adm lp sync shutdown halt mail ftp postfix sshd tcpdump 2gadmin apache zabbix mysql zend rpc 2daygeek named mageshm
方法 2 :使用 getent 命令
getent
命令顯示Name Service Switch
庫支持的資料庫中的條目。這些庫的配置文件為/etc/nsswitch.conf
。
getent
命令顯示類似於/etc/passwd
文件的用戶詳細信息,它將每個用戶詳細信息顯示為包含七個欄位的單行。
# getent passwd 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 ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin postfix:x:89:89::/var/spool/postfix:/sbin/nologin sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin tcpdump:x:72:72::/:/sbin/nologin 2gadmin:x:500:10::/home/viadmin:/bin/bash apache:x:48:48:Apache:/var/www:/sbin/nologin zabbix:x:498:499:Zabbix Monitoring System:/var/lib/zabbix:/sbin/nologin mysql:x:497:502::/home/mysql:/bin/bash zend:x:502:503::/u01/zend/zend/gui/lighttpd:/sbin/nologin rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin 2daygeek:x:503:504::/home/2daygeek:/bin/bash named:x:25:25:Named:/var/named:/sbin/nologin mageshm:x:506:507:2g Admin - Magesh M:/home/mageshm:/bin/bash
7 個欄位的詳細信息如上所述。
你同樣可以使用 awk
或 cut
命令僅列印出 Linux 系統中所有用戶的用戶名列表。顯示的結果是相同的。
方法 3 :使用 compgen 命令
compgen 是 bash 的內置命令,它將顯示所有可用的命令,別名和函數。
# compgen -u
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
ftp
postfix
sshd
tcpdump
2gadmin
apache
zabbix
mysql
zend
rpc
2daygeek
named
mageshm