【Shell 命令集合 系统管理 】Linux 显示当前登录到系统的用户信息 who命令 使用指南

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: 【Shell 命令集合 系统管理 】Linux 显示当前登录到系统的用户信息 who命令 使用指南

Shell 命令专栏:Linux Shell 命令全解析


描述


who命令用于显示当前登录到系统的用户信息。它显示了登录用户的用户名、终端设备、登录时间以及从何处登录。

who命令的输出通常包含以下列:

  • 用户名:显示当前登录用户的用户名。
  • 终端设备:显示当前登录用户所使用的终端设备,例如tty1或pts/0。
  • 登录时间:显示当前登录用户的登录时间,通常以日期和时间的格式显示。
  • 登录来源:显示当前登录用户的登录来源,即从何处登录到系统,可以是本地终端、远程终端或X显示器。

who命令的输出可以帮助管理员了解当前系统上的用户活动情况。通过查看登录用户的信息,管理员可以监控系统资源的使用情况、检查登录用户的身份和权限、查找系统上的空闲终端等。

总之,who命令是一个简单而有用的工具,用于显示当前登录用户的信息,以及他们登录到系统的时间和位置。


语法格式

who [OPTION]... [FILE]...

参数说明

  • -a, --all:显示所有用户的登录信息,包括空闲用户和系统启动时间。
  • -b, --boot:显示系统的启动时间。
  • -d, --dead:显示已经注销的用户信息。
  • -H, --heading:显示表头信息。
  • -i, --idle:显示用户的空闲时间。
  • -l, --login:显示用户的登录名称。
  • -m, --me:只显示当前终端登录的用户。
  • -p, --process:显示每个登录用户的相关进程信息。
  • -q, --count:统计登录用户的数量。
  • -r, --runlevel:显示系统的运行级别。
  • -s, --short:只显示用户的登录名称和终端设备。
  • -T, --mesg:显示终端的类型。
  • -u, --users:显示当前登录用户的用户名。
  • -w, --message:显示用户的登录信息。
  • -t, --time:显示用户的登录时间。
  • --help:显示帮助信息并退出。
  • --version:显示版本信息并退出。

错误情况

  • 如果未提供任何参数或文件名,则默认显示当前登录用户的信息。
  • 如果指定的文件不存在或无效,则会显示错误信息。
  • 如果使用了无效的选项,则会显示错误信息。
  • 如果当前用户无权限查看其他用户的信息,则会显示权限错误信息。

注意事项

在使用Linux Shell的who命令时,需要注意以下几个方面:

  1. 权限限制:一般情况下,who命令可以被任何用户使用来查看登录信息。然而,如果当前用户没有足够的权限来查看其他用户的信息,可能会受到权限限制的错误。在这种情况下,需要以root用户或具有足够权限的用户身份运行who命令。
  2. 参数的正确使用:who命令有多个选项和参数,使用时需要确保正确使用这些选项和参数。不正确的参数使用可能导致错误的输出或不符合预期的结果。
  3. 文件名的指定:who命令可以指定一个或多个文件名作为参数,以显示这些文件中的登录信息。在指定文件名时,需要确保文件存在且具有正确的权限。否则,可能会出现文件不存在或无效的错误。
  4. 输出信息的解读:who命令的输出信息可能会包含一些缩写或特殊符号,需要对这些信息进行正确的解读。例如,终端设备可能以tty开头,或者显示为pts/0等形式。
  5. 并发登录的处理:如果有多个用户同时登录到系统,并使用who命令查看登录信息,可能会出现并发登录的情况。在这种情况下,输出的信息可能会有多个用户同时显示。需要注意区分不同用户的登录信息。

总之,在使用Linux Shell的who命令时,需要注意权限限制、参数的正确使用、文件名的指定、输出信息的解读以及并发登录的处理。这样可以确保正确地获取和解析登录信息。


底层实现

Linux Shell的who命令底层是通过读取系统的登录信息文件来实现的。具体而言,它主要依赖于以下两个文件:

  1. /var/run/utmp:这个文件记录了当前登录到系统的用户信息。它包含了每个登录用户的用户名、终端设备、登录时间等信息。who命令会读取该文件,然后解析其中的内容来显示用户信息。
  2. /var/log/wtmp:这个文件记录了系统的登录和注销事件。它记录了用户的登录和注销时间、登录终端等信息。who命令在统计登录用户数量时,会读取该文件来获取登录和注销事件的记录。

当执行who命令时,它会打开这两个文件,并按照一定的格式解析文件内容,提取所需的信息。然后,根据命令行参数的不同,who命令会对这些信息进行处理和过滤,最终将结果输出到终端。

需要注意的是,who命令在读取登录信息文件时需要相应的权限。一般情况下,这个命令需要以root用户或具有足够权限的用户身份运行,才能够读取和解析这些文件。

总之,Linux Shell的who命令底层通过读取系统的登录信息文件来获取用户的登录信息,并根据命令行参数对这些信息进行处理和过滤,最终将结果显示给用户。


示例

示例一

who

显示当前登录到系统的用户信息。

示例二

who -a

显示当前登录到系统的用户信息,并包括系统启动时间和运行级别。

示例三

who -m

显示当前登录到系统的用户信息,并只显示当前终端登录的用户。

示例四

who -q

显示当前登录到系统的用户信息,并统计登录用户的数量。

示例五

who -r

显示当前登录到系统的用户信息,并显示系统的运行级别。

示例六

who -s

显示当前登录到系统的用户信息,并只显示用户的登录名称和终端设备。

示例七

who -T

显示当前登录到系统的用户信息,并显示终端的类型。


用c语言实现


以下是一个使用C语言编写的简单示例,实现了类似于who命令的功能。代码中使用了utmp.h头文件来读取系统的登录信息。

#include <stdio.h>
#include <utmp.h>
#include <fcntl.h>
#include <unistd.h>
int main() {
    struct utmp current_record;
    int utmp_fd;
    int record_size = sizeof(current_record);
    // 打开utmp文件
    if ((utmp_fd = open(UTMP_FILE, O_RDONLY)) == -1) {
        perror(UTMP_FILE);
        return 1;
    }
    // 读取utmp文件中的记录,直到读取完所有记录
    while (read(utmp_fd, &current_record, record_size) == record_size) {
        // 只显示类型为USER_PROCESS的记录,即登录用户的记录
        if (current_record.ut_type == USER_PROCESS) {
            // 输出用户名和终端设备
            printf("%-8.8s ", current_record.ut_user);
            printf("%-12.12s ", current_record.ut_line);
            // 输出登录时间
            printf("%.24s ", ctime((time_t*)&current_record.ut_tv.tv_sec));
            
            // 输出登录来源
            printf("(%s)\n", current_record.ut_host);
        }
    }
    // 关闭utmp文件
    if (close(utmp_fd) == -1) {
        perror("close");
        return 1;
    }
    return 0;
}

该示例使用了utmp.h头文件来访问系统的登录信息。它打开/var/run/utmp文件,并循环读取文件中的记录。只有类型为USER_PROCESS的记录被视为登录用户的记录,然后输出用户名、终端设备、登录时间和登录来源。最后,关闭文件并返回。

请注意,此示例只是一个简单的示例,可能无法处理所有特殊情况和错误处理。在实际使用中,可能需要添加更多的代码来处理异常情况和更全面的功能。


结语

在我们的探索过程中,我们已经深入了解了Shell命令的强大功能和广泛应用。然而,学习这些技术只是开始。真正的力量来自于你如何将它们融入到你的日常工作中,以提高效率和生产力。

心理学告诉我们,学习是一个持续且积极参与的过程。所以,我鼓励你不仅要阅读和理解这些命令,还要动手实践它们。尝试创建自己的命令,逐步掌握Shell编程,使其成为你日常工作的一部分。

同时,请记住分享是学习过程中非常重要的一环。如果你发现本博客对你有帮助,请不吝点赞并留下评论。分享你自己在使用Shell命令时遇到的问题或者有趣的经验,可以帮助更多人从中学习。

此外,我也欢迎你收藏本博客,并随时回来查阅。因为复习和反复实践也是巩固知识、提高技能的关键。

最后,请记住:每个人都可以通过持续学习和实践成为Shell编程专家。我期待看到你在这个旅途中取得更大进步!

目录
相关文章
|
2月前
|
Shell Linux
Linux shell编程学习笔记30:打造彩色的选项菜单
Linux shell编程学习笔记30:打造彩色的选项菜单
|
23天前
|
Web App开发 网络协议 Linux
linux命令总结(centos):shell常用命令汇总,平时用不到,用到就懵逼忘了,于是专门写了这篇论文,【便持续更新】
这篇文章是关于Linux命令的总结,涵盖了从基础操作到网络配置等多个方面的命令及其使用方法。
52 1
linux命令总结(centos):shell常用命令汇总,平时用不到,用到就懵逼忘了,于是专门写了这篇论文,【便持续更新】
|
9天前
|
监控 网络协议 Shell
ip和ip网段攻击拦截系统-绿叶结界防火墙系统shell脚本
这是一个名为“小绿叶技术博客扫段攻击拦截系统”的Bash脚本,用于监控和拦截TCP攻击。通过抓取网络数据包监控可疑IP,并利用iptables和firewalld防火墙规则对这些IP进行拦截。同时,该系统能够查询数据库中的白名单,确保合法IP不受影响。此外,它还具备日志记录功能,以便于后续分析和审计。
34 6
|
5天前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
2月前
|
Shell Linux
Linux shell编程学习笔记82:w命令——一览无余
Linux shell编程学习笔记82:w命令——一览无余
|
27天前
|
存储 Shell Linux
【Linux】shell基础,shell脚本
Shell脚本是Linux系统管理和自动化任务的重要工具,掌握其基础及进阶用法能显著提升工作效率。从简单的命令序列到复杂的逻辑控制和功能封装,Shell脚本展现了强大的灵活性和实用性。不断实践和探索,将使您更加熟练地运用Shell脚本解决各种实际问题
20 0
|
6月前
|
缓存 Linux 测试技术
安装【银河麒麟V10】linux系统--并挂载镜像
安装【银河麒麟V10】linux系统--并挂载镜像
1526 0
|
6月前
|
关系型数据库 MySQL Linux
卸载、下载、安装mysql(Linux系统centos7)
卸载、下载、安装mysql(Linux系统centos7)
228 0
|
18天前
|
Linux
手把手教会你安装Linux系统
手把手教会你安装Linux系统
|
2月前
|
Ubuntu Linux 网络安全
从头安装Arch Linux系统
本文记录了作者安装Arch Linux系统的过程,包括安装成果展示和遇到的疑难点及其解决方法,如硬盘不足、下载失败、设置时区、安装微码和配置无密码登录等。
从头安装Arch Linux系统