who命令显示当前登录用户的基本信息,w命令则进一步提供用户正在执行的命令及资源消耗;who适用于快速查看在线用户,w用于深入分析系统负载和用户活动。

在Linux系统中,管理用户会话的核心在于理解当前谁在使用系统,以及他们在做什么。简单来说,
who命令告诉你“谁在线”,而
w命令则更进一步,揭示了“谁在做什么”及其具体活动,这对于系统监控和故障排查至关重要。
管理用户会话,其实不仅仅是简单的查看,它更像是一种对系统状态的洞察。我们想知道的,往往不只是有多少人在线,而是这些人是不是在做一些耗费资源的操作,或者有没有未经授权的登录。
w和
who命令正是提供这种洞察力的基础工具。
who命令提供了一个快速的概览,告诉你哪些用户在哪个终端上登录,以及登录的时间。这就像是点名,迅速知道有哪些人到场了。而
w命令则是一个更深入的“监视器”,它不仅显示
who命令的信息,还会告诉你这些用户当前正在执行什么命令,以及他们的CPU使用情况。这对于判断系统负载的来源,或者排查某个用户是否异常活跃,都提供了非常直接的线索。
Linux系统下查看当前用户登录信息的实用技巧
在Linux环境中,了解当前有哪些用户登录,以及他们都在做什么,是系统管理员日常工作中不可或缺的一部分。除了最常用的
who和
w命令,还有一些其他工具也能提供类似甚至更详细的信息。
who命令,在我看来,更像是一个“签到表”。当你输入
who,它会列出当前所有登录的用户,他们的终端(TTY或PTS),登录时间,以及可能的远程主机。例如:
$ who user1 pts/0 2023-10-27 10:00 (192.168.1.100) user2 pts/1 2023-10-27 10:15 (192.168.1.101)
这很直接,告诉我
user1和
user2在线。但如果我想知道
user1是不是正在编译代码,或者
user2是不是在跑一个耗时的脚本,
who就帮不上忙了。
这时候,
w命令就显得尤为强大。它不仅包含了
who命令的基本信息,还增加了每个用户的空闲时间、JCPU(所有进程的总CPU时间)、PCPU(当前进程的CPU时间)以及他们当前正在执行的命令。它的输出通常是这样的:
$ w 10:30:05 up 2 days, 20:05, 2 users, load average: 0.10, 0.08, 0.05 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT user1 pts/0 192.168.1.100 10:00 2.00s 0.10s 0.02s bash user2 pts/1 192.168.1.101 10:15 10m 1.20s 0.80s vim file.txt
从这里,我能清晰地看到
user1可能只是开着一个
bash会话,而
user2正在编辑
file.txt。这信息量就大多了,对于快速判断系统负载的来源非常有帮助。
此外,
users命令可以快速列出所有登录用户的用户名,通常一行显示多个。
last命令则能查看系统历史登录记录,包括重启信息,这对于安全审计和追踪用户活动历史非常有用。有时候,我也会用
ps -ef | grep pts或
ps -ef | grep tty来结合进程信息,进一步确认某个终端上的活动。这些工具各有侧重,但
w和
who无疑是日常监控的基石。
深度解析:w命令输出的每一列都代表什么?
w命令的输出虽然信息量大,但初次接触可能会觉得有点眼花缭乱。理解每一列的含义,是充分利用这个命令的关键。我们再来看一个典型的
w命令输出示例:
$ w 10:30:05 up 2 days, 20:05, 2 users, load average: 0.10, 0.08, 0.05 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT user1 pts/0 192.168.1.100 10:00 2.00s 0.10s 0.02s bash user2 pts/1 192.168.1.101 10:15 10m 1.20s 0.80s vim file.txt
让我们逐一拆解:
-
第一行(Header Line):
10:30:05
: 当前系统时间。up 2 days, 20:05
: 系统已运行的时间。2 users
: 当前登录的用户数量。load average: 0.10, 0.08, 0.05
: 这是系统负载平均值,分别代表过去1分钟、5分钟和15分钟内,等待运行的进程平均数量。这对我判断系统是否繁忙至关重要。
USER: 登录系统的用户名。
TTY: 用户登录的终端类型。
tty
通常指物理终端或虚拟控制台,pts
(pseudo-terminal slave)则指通过SSH、Telnet等远程登录的伪终端。FROM: 用户登录的远程主机IP地址或主机名。如果是本地登录,这列可能为空或显示
:0
。LOGIN@: 用户登录系统的时间点。这对于判断用户在线时长很有用。
IDLE: 用户会话空闲的时间。如果这个值很大,说明用户可能离开了终端,或者只是保持会话开启但没有活动。
s
表示秒,m
表示分钟,h
表示小时,d
表示天。JCPU (JCPU Time): 这是与该终端会话相关的所有进程(包括后台进程)累计的CPU使用时间。它反映了该用户在整个会话期间对CPU的累积消耗。
PCPU (PCPU Time): 这是用户当前正在执行的进程(即
WHAT
列显示的命令)所消耗的CPU时间。这个值能直接告诉我当前哪个命令是CPU密集型的。WHAT: 用户当前正在执行的命令或程序。这是
w
命令最直观、最有用的信息之一,能直接揭示用户活动。
通过这些信息,我可以迅速判断出
user2正在使用
vim,并且这个
vim进程已经消耗了0.80秒的CPU时间,而其整个会话的CPU消耗是1.20秒。如果我看到某个用户的
WHAT是
python script.py,并且
PCPU和
JCPU都非常高,我就知道这个用户正在运行一个计算密集型任务,这可能就是系统负载高的原因。这种细致的分析,是
w命令的价值所在。
在实际系统管理中,何时选择who,何时选择w?
在日常的Linux系统管理和监控中,
who和
w命令虽然都用于查看用户会话,但它们各自有最适合的应用场景。我的经验告诉我,选择哪个命令,取决于你当前想要获取的信息深度和目的。
当你需要快速、粗略地了解当前有哪些用户登录系统时,
who命令是首选。比如,我只是想知道今天有多少同事远程登录了服务器,或者确认某个特定用户是否在线,
who命令就能立刻给出答案。它的输出简洁明了,没有额外的进程信息,这使得它在脚本中或者需要快速验证用户在线状态时非常高效。
举个例子,如果我怀疑某个服务中断是由于某个特定用户登录后误操作导致的,我可能会先用
who快速确认这个用户是否在线。如果在线,我再考虑进一步的排查。
而
w命令,则在我需要深入了解用户活动细节时发挥作用。当系统负载突然升高,或者我发现某个进程异常消耗资源时,
w命令是我的第一选择。它能告诉我每个登录用户当前正在执行什么命令,以及这些命令的CPU消耗情况。这就像是查看监控摄像头的实时画面,我能看到每个“住户”都在做什么。
例如,如果我看到系统负载飙升,我立刻敲下
w。如果某个用户的
WHAT显示的是
stress-ng或者一个我没见过的编译命令,并且
PCPU和
JCPU都非常高,那么我基本上就能定位到问题的根源了。我可以进一步通过
top或
htop来确认,甚至联系该用户了解情况。
总结来说,
who命令适用于:
- 快速查看当前登录用户列表。
- 确认某个用户是否在线。
- 作为脚本中判断用户在线状态的轻量级工具。
w命令则适用于:
- 分析系统负载来源,定位是哪个用户或哪个进程导致的高负载。
- 监控用户活动,了解用户正在执行的具体任务。
- 排查异常行为,例如某个用户长时间空闲但
JCPU
却很高,可能意味着有后台任务在运行。 - 在需要更详细的用户会话信息时,提供进程级别的洞察。
我个人在使用时,往往是先用
who做个快速扫描,如果发现用户数量异常或者有需要关注的用户,就会立即切换到
w来做更细致的探查。这两个命令,就像是我的左右手,在Linux系统管理中协同工作,帮助我保持对系统状态的全面掌握。










