Linuxjournalctl命令详解与使用教程
时间:2026-02-24 12:38:22 314浏览 收藏
本文深入解析了Linux系统中强大的日志管理命令journalctl,它专为Systemd架构设计,能高效读取二进制日志数据,支持灵活多维的筛选方式——包括按时间(如“今天”“一小时前”或精确时间点)、服务单元(如ssh.service)、进程ID、用户UID、日志优先级(从emerg到debug)等精准过滤,并提供实时跟踪(-f)、格式化导出(文本/JSON)及智能清理(按时间或空间限制)等实用功能,是运维人员和开发者在Ubuntu 22.04等现代Linux发行版中排查故障、审计行为和优化系统日志管理不可或缺的利器。

如果您需要在基于Systemd的Linux系统中查看和分析系统日志,但发现传统的日志工具难以满足需求,则可以使用journalctl命令直接访问由systemd-journald服务收集的日志数据。以下是使用journalctl查看和管理日志的具体方法。
本文运行环境:Dell XPS 13,Ubuntu 22.04
一、查看基本日志信息
journalctl默认显示系统所有日志条目,从最旧的开始输出。它能读取二进制格式的日志文件,无需手动解析文本日志。
1、打开终端并输入journalctl,按回车执行,将列出完整的系统日志。
2、使用翻页键或鼠标滚轮浏览内容,日志按时间顺序排列,最新条目位于底部。
二、按时间范围筛选日志
通过指定时间参数,可以缩小日志查询范围,便于定位特定时间段内的事件。
1、查看今天的日志:journalctl --since today。
2、查看昨天的日志:journalctl --since yesterday --until today。
3、查看最近一小时的日志:journalctl --since "-1 hour"。
4、使用精确时间点,例如:journalctl --since "2023-10-01 10:00:00" --until "2023-10-01 11:00:00"。
三、按服务单元过滤日志
针对某个特定服务(如sshd、nginx等)查看其运行日志,有助于快速排查问题。
1、查看SSH服务日志:journalctl -u ssh.service。
2、实时跟踪服务日志变化:journalctl -u nginx.service -f,其中-f表示持续输出新日志。
3、结合时间筛选查看某服务昨日运行情况:journalctl -u cron.service --since yesterday。
四、按进程或用户ID查询日志
通过PID或UID过滤日志,可用于审计特定进程或用户的操作行为。
1、查看指定PID的日志:journalctl _PID=1234。
2、查看属于特定用户ID的日志:journalctl UID=1000。
3、查找与当前登录用户相关的会话日志:journalctl SESSION=c1(会话编号可通过loginctl list-sessions获取)。
五、按日志优先级筛选
Linux系统日志分为多个等级,使用级别过滤可聚焦关键错误信息。
1、仅显示错误及以上级别的日志:journalctl -p err。
2、查看警告信息:journalctl -p warning。
3、支持的优先级包括:emerg、alert、crit、err、warning、notice、info、debug,数值从0到7递增。
4、使用数值形式过滤,例如:journalctl -p 3 等同于 -p err。
六、导出与清理日志数据
为节省磁盘空间或进行外部分析,可将日志导出为文件或清除旧日志。
1、将全部日志保存到文本文件:journalctl > system_log.txt。
2、以JSON格式导出便于程序处理:journalctl -o json > log.json。
3、删除超过七天的日志:journalctl --vacuum-time=7d。
4、限制日志占用最大磁盘空间:journalctl --vacuum-size=500M。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
319 收藏
-
122 收藏
-
465 收藏
-
375 收藏
-
342 收藏
-
450 收藏
-
400 收藏
-
444 收藏
-
102 收藏
-
460 收藏
-
254 收藏
-
401 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习