/etc/passwd 文件是 linux 系统中用于存储用户基本信息的文件,每一行代表一个用户,包含7个字段:用户名、密码占位符、uid、gid、用户描述、主目录和登录shell。1. 使用 cat /etc/passwd 可查看全部内容;2. 用 cut -d: -f1 /etc/passwd 只显示用户名;3. 通过 awk -f: '$3 >= 1000 {print $1}' /etc/passwd 过滤普通用户;4. 用 grep 结合 shell 类型可找出可登录用户。linux用户分为三类:root(uid 0)、系统用户(uid 1~999)和普通用户(uid ≥ 1000),可通过 uid 和登录shell区分类型。注意不要随意修改该文件,系统账户通常不可登录。
在Linux系统中,查看所有用户最直接的方法是读取 /etc/passwd 文件。这个文件记录了系统中所有用户的基本信息,包括系统账户和普通用户账户。
这个文件并不是用来存储密码的(密码一般存在 /etc/shadow 中),而是保存了用户的基本配置信息。每一行代表一个用户,字段之间用冒号 : 分隔,一共有7个字段,分别是:
例如一行内容可能是这样的:
john:x:1001:1001:John Doe:/home/john:/bin/bash
你可以使用以下几种方式来查看 /etc/passwd 的内容:
使用 cat 命令:
cat /etc/passwd
使用 less 或 more 分页查看:
less /etc/passwd
只显示用户名(第一列):
cut -d: -f1 /etc/passwd
过滤出“正常用户”(比如 UID ≥ 1000):
awk -F: '$3 >= 1000 {print $1}' /etc/passwd
系统自带的账户(如 root, daemon, nobody 等)通常 UID 比较小,而普通用户一般从 UID 1000 开始。
Linux中的用户大致分为三类:
通过查看 UID 字段就能判断用户类型。例如下面这行是一个系统用户:
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
注意它的 Shell 是 /usr/sbin/nologin,说明这个账户无法交互式登录。
如果你只是想快速确认系统里有哪些可登录的用户,可以结合 Shell 类型进行过滤:
grep -E '/bin/bash|/bin/zsh|/bin/sh' /etc/passwd | cut -d: -f1
这样会列出使用常见 Shell 的用户,通常是实际登录用户。
基本上就这些。掌握 /etc/passwd 的结构和查看方法,能帮助你更好地了解系统用户情况,也便于排查权限或登录相关的问题。
以上就是如何查看Linux系统中的所有用户?/etc/passwd文件解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号