当前位置:首页 > 文章列表 > 文章 > linux > Linux用户登录记录查看方法

Linux用户登录记录查看方法

2026-05-06 13:01:47 0浏览 收藏
本文深入解析了Linux系统中查看用户登录记录的核心命令与日志机制,重点讲解了`last`(读取二进制`/var/log/wtmp`,追踪完整成功登录历史)、`lastb`(分析失败登录的`/var/log/btmp`)和`lastlog`(仅显示各用户最后一次登录的`/var/log/lastlog`)三者的功能差异、使用技巧及权限限制;同时揭示了日志可靠性背后的隐患——如wtmp可被root清空、时间篡改会留下`date |`标记、日志不全可能源于循环覆盖或系统精简配置,并强调在安全敏感场景下必须结合多源日志(如auth.log、journalctl)与远程集中审计才能确保记录真实可信。

Linux怎么查看用户登录记录_Linux分析last命令日志【精华】

last 命令默认看的是哪个文件?

它读的是 /var/log/wtmp —— 一个二进制日志文件,记录所有成功登录、登出、重启、关机事件。这不是文本文件,不能用 catless 直接打开;强行查看只会输出乱码。所以必须用 last 解析,这是设计使然,不是 bug。

  • 普通用户也能执行 last,但只能看到自己有权限读的日志内容(通常全部可见)
  • 若系统时间被手动改过,last 输出里会出现 date |date { 这样的特殊行,代表日志时间戳断层,需警惕人为干预或时钟异常
  • wtmp 不会自动轮转,长期运行的服务器上这个文件可能越来越大,但一般不影响 last 使用;真要清理,得用 logrotate 配置或手动截断(不推荐直接删)

怎么快速定位某个用户的登录行为?

直接加用户名就行:last username。比如查 root 最近 5 次登录:last -n 5 root。输出里每行包含终端(如 pts/0)、来源 IP(如果远程 SSH)、登录起止时间、持续时长。

  • 如果某行末尾显示 still logged in,说明该会话当前仍活跃,对应进程可能还在跑
  • IP 地址没显示?加上 -a 参数:last -a root,它会把 IP 放在最后一列输出
  • 想排除主机名干扰(比如只关心 IP),加 -Rlast -R -a root
  • 注意:last 显示的是“历史成功登录”,不包含失败尝试——那是 lastb 的职责,它读的是 /var/log/btmp

lastlog 和 last 有什么根本区别?

lastlog 看的是 /var/log/lastlog,只存每个用户「最后一次」登录信息(精确到秒),按 UID 排序,不按时间倒序;而 last 看的是 wtmp,是完整时间线的登录流水账。

  • lastlog 必须 root 才能运行,否则报错:Permission denied
  • 查某个用户最后一次啥时候登过:lastlog -u username
  • 查最近 7 天内有谁登过:lastlog -t 7;查 7 天前的登录:lastlog -b 7
  • 一个用户从没登录过,lastlog 就显示 **Never logged in**,很直观;last 则完全不会出现这个人

遇到日志“消失”或“不全”怎么办?

先别急着怀疑被删,wtmp 是循环覆盖式写入的,旧记录会被新记录顶掉;而且某些精简版系统(如容器或嵌入式)压根不启用 wtmp 记录。

  • 确认 wtmp 是否存在且非空:ls -lh /var/log/wtmp,大小为 0 表示没记录或损坏
  • 查更细粒度的登录过程(比如认证阶段),翻 /var/log/auth.log(Debian/Ubuntu)或 /var/log/secure(RHEL/CentOS)
  • 如果 last 输出突然中断(比如只显示到上周),可能是 wtmp 被清空过,或者系统启用了 logrotate 但没配好归档策略
  • 别依赖单一日志源:结合 last(成功登录)、lastb(失败登录)、journalctl _COMM=sshd(SSH 详细会话)交叉验证
真正关键的不是“有没有记录”,而是“记录是否可信”。wtmp 可被 root 清空,auth.log 可被重定向或关闭——高安全场景下,得靠集中日志系统(如 rsyslog + remote server)防篡改。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

PHP安装RabbitMQ扩展详细教程PHP安装RabbitMQ扩展详细教程
上一篇
PHP安装RabbitMQ扩展详细教程
Golangnet包TCP连接实战教程
下一篇
Golangnet包TCP连接实战教程
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ljg-skills -
    ljg-skills
    ljg-skills 是李继刚开源的 AI 技能与提示词集合,面向大模型使用者整理了一批可复用的 prompt、角色设定和任务技能模板,适合用于学习提示词设计、搭建个人 AI 工作流和沉淀团队常用智能体能力。
    1324次使用
  • MELO音乐 - AI 音乐生成平台,支持多模态创作能力
    MELO音乐
    MELO音乐是一站式AI视频与音乐制作助手,对标suno, udio的高品质体验。提供伴奏生成、原创写词、无损导出、哼唱识曲、混音变声等全套音频与短视频编辑工具。无论是流行Kpop、电音说唱、民谣古风、摇滚儿歌还是商用轻音乐,MELO为你免费谱曲,轻松做同款!
    1261次使用
  • UniScribe - AI 免费在线音视频转文字平台
    UniScribe
    UniScribe 是一款 AI 音视频转文字与内容整理工具,支持上传音频、视频文件或粘贴 YouTube 链接,自动生成转写文本、摘要、思维导图和关键问题,并支持多格式导出,适合会议记录、课程学习、访谈整理和内容创作复盘。
    1209次使用
  • 剧云 - 免费 AI 智能中文剧本创作平台
    剧云
    剧云是专业中文剧本创作平台,安全稳定运行十余年,集成AI编剧、剧本医生审核、人物小传、剧情关系图、大纲编写、多人协作、Word导入导出、版权管控功能,数据安全防护,轻松高效创作剧本。
    1381次使用
  • 万象有声 - AI 一站式有声内容创作平台
    万象有声
    万象有声,一个专为有声创作者打造的新一代智能有声内容创作平台。平台提供专业的智能拆章、智能画本编辑、AI配音、AI生成音效、后期制作、智能对轨、智能审听等有声创作全流程工具,可以帮助创作者高效、低成本创作出引人入胜的有声作品。立即体验,让有声书制作更简单!
    1382次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码