Linux用户登录记录查看方法
时间:2026-02-10 10:56:02 439浏览 收藏
本篇文章给大家分享《Linux查看用户登录记录方法》,覆盖了文章的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。
last 命令默认读取 /var/log/wtmp 文件,该二进制日志记录所有成功登录、登出、重启和关机事件,需用 last 解析,不可直接用 cat 或 less 查看。

last 命令默认看的是哪个文件?
它读的是 /var/log/wtmp —— 一个二进制日志文件,记录所有成功登录、登出、重启、关机事件。这不是文本文件,不能用 cat 或 less 直接打开;强行查看只会输出乱码。所以必须用 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),加
-R:last -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)防篡改。今天关于《Linux用户登录记录查看方法》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
300 收藏
-
456 收藏
-
102 收藏
-
384 收藏
-
114 收藏
-
196 收藏
-
212 收藏
-
133 收藏
-
465 收藏
-
150 收藏
-
179 收藏
-
281 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习