登录
首页 >  文章 >  linux

Linuxjournalctl命令详解与使用技巧

时间:2025-12-12 16:18:38 395浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

目前golang学习网上已经有很多关于文章的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《LINUX journalctl命令使用教程》,也希望能帮助到大家,如果阅读完后真的对你学习文章有帮助,欢迎动动手指,评论留言并分享~

journalctl可查看Systemd日志,支持按时间(如--since today)、服务(-u ssh.service)、PID(_PID=1234)、用户(UID=1000)、优先级(-p err)筛选,还能导出(>file)或清理(--vacuum-time=7d)日志。

LINUX的journalctl命令怎么用_Systemd下查看与分析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

理论要掌握,实操不能落!以上关于《Linuxjournalctl命令详解与使用技巧》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>