关于linux:linux-查看所有用户的三种方式

9次阅读

共计 2515 个字符,预计需要花费 7 分钟才能阅读完成。

通过应用 /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 文件将每个用户的详细信息写为一行,其中蕴含七个字段,每个字段之间用冒号 : 分隔:

[root@centosb ~]# 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
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/false
ntp:x:38:38::/etc/ntp:/sbin/nologin

7 个字段的详细信息如下。

用户名(ntp):已创立用户的用户名,字符长度 1 个到 12 个字符。
明码(x):代表加密明码保留在 /etc/shadow 文件中。
用户 ID(38):代表用户的 ID 号,每个用户都要有一个惟一的 ID。UID 号为 0 的是为 root 用户保留的,UID 号 1 到 99 是为零碎用户保留的,UID 号 100-999 是为零碎账户和群组保留的。
群组 ID(38):代表群组的 ID 号,每个群组都要有一个惟一的 GID,保留在 /etc/group 文件中。
用户信息(MySQL Server):代表形容字段,能够用来形容用户的信息(LCTT 译注:此处原文疑有误)。
家目录(/var/lib/mysql):代表用户的家目录。
Shell(/bin/false):代表用户应用的 shell 类型。

  你能够应用 awk 或 cut 命令仅打印出 Linux 零碎中所有用户的用户名列表。显示的后果是雷同的。

[root@centosb ~]# awk -F':' '{print $1}' /etc/passwd
root
bin
daemon
adm
lp
sync
shutdown
halt
mail
operator
games
ftp
nobody
systemd-network
dbus
polkitd
tss
abrt
sshd
postfix
chrony
mysql
ntp
  1. 应用 getent 命令
    getent 命令显示 Name Service Switch 库反对的数据库中的条目。这些库的配置文件为 /etc/nsswitch.conf
    getent 命令显示相似于 /etc/passwd 文件的用户详细信息,它将每个用户详细信息显示为蕴含七个字段的单行。
getent passwd
  1. 应用 compgen 命令

compgen 是 bash 的内置命令,它将显示所有可用的命令,别名和函数。

compgen -u
正文完
 0