天天看點

檢視linux中所有使用者的三種方式cat /etc/passwdawk -F':' '{ print $1}' /etc/passwdcut -d: -f1 /etc/passwdgetent passwdcompgen -u

檢視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

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

7 個字段的詳細資訊如上所述。

你同樣可以使用 awk 或 cut指令僅列印出 Linux 系統中所有使用者的使用者名清單。顯示的結果是相同的。

方法 3 :使用 compgen 指令

compgen 是 bash 的内置指令,它将顯示所有可用的指令,别名和函數。

compgen -u

原文位址

https://www.cnblogs.com/hongsandao/p/11333725.html