檢視linux中所有使用者的三種方式
通過使用/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
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
7 個字段的詳細資訊如上所述。
你同樣可以使用 awk 或 cut指令僅列印出 Linux 系統中所有使用者的使用者名清單。顯示的結果是相同的。
方法 3 :使用 compgen 指令
compgen 是 bash 的内置指令,它将顯示所有可用的指令,别名和函數。
compgen -u
原文位址
https://www.cnblogs.com/hongsandao/p/11333725.html