溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

linux如何查看所有用戶

發(fā)布時間:2023-02-09 14:09:23 來源:億速云 閱讀:513 作者:iii 欄目:建站服務器

這篇文章主要介紹“l(fā)inux如何查看所有用戶”,在日常操作中,相信很多人在linux如何查看所有用戶問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”linux如何查看所有用戶”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

linux查看所有用戶的方法:1、使用cat等文件操作命令讀取“/etc/passwd”文件的內(nèi)容,可打印Linux系統(tǒng)上創(chuàng)建的用戶列表。2、使用getent命令查看,語法“getent passwd”,可以顯示類似于“/etc/passwd”文件的用戶詳細信息。3、使用compgen命令,語法“compgen -u”。

大家都知道,Linux 系統(tǒng)中用戶信息存放在 /etc/passwd 文件中。

這是一個包含每個用戶基本信息的文本文件。當我們在系統(tǒng)中創(chuàng)建一個用戶,新用戶的詳細信息就會被添加到這個文件中。

/etc/passwd 文件將每個用戶的基本信息記錄為文件中的一行,一行中包含 7 個字段。

/etc/passwd 文件的一行代表一個單獨的用戶。該文件將用戶的信息分為 3 個部分。

* 第 1 部分:`root` 用戶信息
* 第 2 部分:系統(tǒng)定義的賬號信息
* 第 3 部分:真實用戶的賬戶信息

第一部分是 root 賬戶,這代表管理員賬戶,對系統(tǒng)的每個方面都有完全的權(quán)力。

第二部分是系統(tǒng)定義的群組和賬戶,這些群組和賬號是正確安裝和更新系統(tǒng)軟件所必需的。

第三部分在最后,代表一個使用系統(tǒng)的真實用戶。

在創(chuàng)建新用戶時,將修改以下 4 個文件。

* `/etc/passwd`: 用戶賬戶的詳細信息在此文件中更新。
* `/etc/shadow`: 用戶賬戶密碼在此文件中更新。
* `/etc/group`: 新用戶群組的詳細信息在此文件中更新。
* `/etc/gshadow`: 新用戶群組密碼在此文件中更新。

方法 1 :使用 /etc/passwd 文件

使用任何一個像 cat、more、less 等文件操作命令來打印 Linux 系統(tǒng)上創(chuàng)建的用戶列表。

/etc/passwd 是一個文本文件,其中包含了登錄 Linux 系統(tǒng)所必需的每個用戶的信息。它保存用戶的有用信息,如用戶名、密碼、用戶 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): 已創(chuàng)建用戶的用戶名,字符長度 1 個到 12 個字符。

  • 密碼(x):代表加密密碼保存在 `/etc/shadow 文件中。

  • **用戶 ID(506):代表用戶的 ID 號,每個用戶都要有一個唯一的 ID 。UID 號為 0 的是為 root 用戶保留的,UID 號 1 到 99 是為系統(tǒng)用戶保留的,UID 號 100-999 是為系統(tǒng)賬戶和群組保留的。

  • **群組 ID (507):代表群組的 ID 號,每個群組都要有一個唯一的 GID ,保存在 /etc/group文件中。

  • **用戶信息(2g Admin - Magesh M):代表描述字段,可以用來描述用戶的信息(LCTT 譯注:此處原文疑有誤)。

  • **家目錄(/home/mageshm):代表用戶的家目錄。

  • **Shell(/bin/bash):代表用戶使用的 shell 類型。

你可以使用 awk 或 cut 命令僅打印出 Linux 系統(tǒng)中所有用戶的用戶名列表。顯示的結(jié)果是相同的。

# 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 庫支持的數(shù)據(jù)庫中的條目。這些庫的配置文件為 /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 譯注:此處內(nèi)容重復,刪節(jié))

你同樣可以使用 awk 或 cut 命令僅打印出 Linux 系統(tǒng)中所有用戶的用戶名列表。顯示的結(jié)果是相同的。

方法 3 :使用 compgen 命令

compgen 是 bash 的內(nèi)置命令,它將顯示所有可用的命令,別名和函數(shù)。

# compgen -u
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
ftp
postfix
sshd
tcpdump
2gadmin
apache
zabbix
mysql
zend
rpc
2daygeek
named
mageshm

到此,關于“l(fā)inux如何查看所有用戶”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI