列出 Linux 系統上所有使用者的 3 種方法
透過使用
/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 個欄位的詳細資訊如上所述。(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
via: https://www.2daygeek.com/3-methods-to-list-all-the-users-in-linux-system/
作者:Magesh Maruthamuthu 選題:lujun9972 譯者:SunWave 校對:wxy
相關文章
- 安全:列出linux中所有可登入shell/ssh/sudo的使用者Linux
- 幾種從Windows上傳檔案到Linux系統的方法WindowsLinux
- centos(linux): 列出所有的開機自啟動程式CentOSLinux
- 在Linux中,如何檢視檔案內容?列出幾種方法。Linux
- Linux 系統中如何檢視當前所有登入的使用者Linux
- python列出資料夾所有檔案有哪些方法?Python
- Linux 上截圖的三種方法Linux
- Linux 系統生成隨機密碼的10種方法Linux隨機密碼
- Linux 中模擬多種系統負載的方法Linux負載
- Linux系統下檢視mysql版本的四種方法LinuxMySql
- 如何查詢Linux系統中密碼為空的所有使用者Linux密碼
- Linux中如何批次刪除系統中所有的自建使用者Linux
- Linux系統下常用的3種網路測速工具!Linux
- Linux系統檢視ntp是否同步的方法有幾種?Linux
- Linux系統下建立檔案最常見的8種方法!Linux
- 在 RHEL 和 CentOS 上檢查或列出已安裝的安全更新的兩種方法CentOS
- Win10系統開啟Windows Powershell的3種方法Win10Windows
- 【分享】Linux系統下3種常用的網路測速工具!Linux
- Linux系統生成隨機密碼的8種方法!Linux運維課程Linux隨機密碼運維
- 列出叢集中所有執行容器的映象
- Linux系統使用者組的管理Linux
- Linux中檢查本地系統上的開放埠列表的方法Linux
- Linux系統命令3Linux
- 深度linux系統怎麼更換賬戶圖片? 深度linux系統使用者頭像的設定方法Linux
- 探討一下Linux系統中使用者ID的五種分類!Linux
- Linux系統上的常用基礎命令,深入使用者與使用者組的相關命令!Linux
- Linux系統使用者賬號的管理Linux
- 線上試用 200 多種 Linux 和 Unix 作業系統Linux作業系統
- Linux 中實時檢視日誌的3種方法Linux
- 使用lsblk命令列出系統中的塊裝置命令列
- git列出所有已經跟蹤檔案Git
- Linux 中獲取硬碟分割槽或檔案系統的 UUID 的七種方法Linux硬碟UI
- 在Linux系統上建立檔案的8個方法,記得收藏哦!Linux
- 基於Linux系統的PXE搭建方法Linux
- 判斷Linux系統是否被黑的方法Linux
- Linux系統學習07-Centos軟體安裝幾種方法LinuxCentOS
- C++檔案系統操作5 - 跨平臺列出指定目錄下的所有檔案和資料夾C++
- Win10系統怎麼開啟使用者和組 win10系統開啟使用者和組的兩種方法Win10