linux檢視所有使用者的方法:1、使用cat等檔案操作命令讀取「/etc/passwd」檔案的內容,可列印Linux系統上建立的使用者列表。2、使用getent命令檢視,語法「getent passwd」,可以顯示類似於「/etc/passwd」檔案的使用者詳細資訊。3、使用compgen命令,語法「compgen -u」。
本教學操作環境:linux7.3系統、Dell G3電腦。
大家都知道,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 個欄位的詳細資訊如下。
你可以使用 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 個欄位的詳細資訊如上所述。(LCTT 譯註:此處內容重複,刪節)
你同樣可以使用 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
登入後複製
相關推薦:《Linux視訊教學》
以上就是linux怎麼檢視所有使用者的詳細內容,更多請關注TW511.COM其它相關文章!