journalctl 日志查看方法

本文详细介绍CentOS 7系统下journalctl的使用方法,涵盖查看各类日志,如内核日志、应用日志、指定服务日志等,以及如何按时间、服务、用户筛选日志,实现日志的实时滚动显示、JSON格式输出和日志存储管理。
部署运行你感兴趣的模型镜像

1  概述

日志管理工具journalctl是centos7上专有的日志管理工具,该工具是从message这个文件里读取信息。Systemd统一管理所有Unit的启动日志。带来的好处就是,可以只用journalctl一个命令,查看所有日志(内核日志和应用日志)。日志的配置文件是/etc/systemd/journald.conf

journalctl功能强大,用法非常多。本文将介绍journalctl的相关使用方法。

2  journalctl 使用方法

 

.查看所有日志

默认情况下,只保存本次启动的日志

journalctl

.查看内核日志(不显示应用日志)

journalctl -k

.查看系统本次启动的日志

journalctl   -b

journalctl  -b  -0

.查看上一次启动的日志

需更改设置,如上次系统崩溃,需要查看日志时,就要看上一次的启动日志。

journalctl  -b -1

.查看指定时间的日志

journalctl --since="2012-10-3018:17:16"

journalctl --since "20 minago"

journalctl --since yesterday

journalctl --since"2015-01-10" --until "2015-01-11 03:00"

journalctl --since 09:00 --until"1 hour ago"

journalctl --since"15:15" --until now

.显示尾部的最新10行日志

journalctl  -n

.显示尾部指定行数的日志

查看的是/var/log/messages的日志,但是格式上有所调整,如主机名格式不一样而已

journalctl -n 20

.实时滚动显示最新日志

journalctl   -f

.查看指定服务的日志

journalctl  /usr/lib/systemd/systemd

.查看指定进程的日志

journalctl   _PID=1

.查看某个路径的脚本的日志

journalctl    /usr/bin/bash

.查看指定用户的日志

journalctl _UID=33  --since today

.查看某个Unit的日志

journalctl  -u nginx.service

journalctl  -u nginx.service  --since  today

.实时滚动显示某个Unit的最新日志

journalctl  -u nginx.service  -f

.合并显示多个Unit的日志

journalctl  -u nginx.service  -u php-fpm.service  --since today

​查看指定优先级(及其以上级别)的日志

日志优先级共有8级

0: emerg

1: alert

2: crit

3: err

4: warning

5: notice

6: info

7: debug

journalctl  -p err  -b

.不分页标准输出

日志默认分页输出--no-pager改为正常的标准输出

journalctl  --no-pager

.以JSON格式(单行)输出

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgramming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java,JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。

JSON建构于两种结构:

“名称/值”对的集合(A collection ofname/value pairs):不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组(associativearray)。

值的有序列表(An ordered list of values):在大部分语言中,它被理解为数组(array)。

这些都是常见的数据结构。事实上大部分现代计算机语言都以某种形式支持它们。这使得一种数据格式在同样基于这些结构的编程语言之间交换成为可能。

例子

以JSON格式(单行)输出

journalctl  -b -u httpd.service  -o json

.以JSON格式(多行)输出,可读性更好,建议选择多行输出

journalctl  -b -u httpd.service  -o json-pretty

.显示日志占据的硬盘空间

journalctl  --disk-usage

.指定日志文件占据的最大空间

journalctl   --vacuum-size=1G

.指定日志文件保存多久

journalctl   --vacuum-time=1years



作者:ghbsunny
链接:https://www.jianshu.com/p/bb51eee23820
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

转载于:https://www.cnblogs.com/leigepython/p/10302056.html

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

<think>我们正在回答用户关于journalctl命令的问题。根据引用内容,我们可以整合相关信息。用户问题:我想使用journalctl命令查看系统日志请问journalctl命令查看 Linux系统日志根据引用,journalctl是一个用于查询systemd日志的命令,systemd是许多现代Linux发行版的初始化系统和服务管理器。回答结构:1.介绍journalctl命令的基本用途2.常用参数和用法示例3.日志持久化设置(因为引用中提到默认可能是非持久化的)4.日志清理和大小限制注意:引用中提供了多个参数和用法,我们需要整理成用户容易理解的形式。同时,根据系统级指令,我们需要在回答中自然地添加引用标识。另外,按照要求,我们需要在回答结束后生成相关问题。开始回答:</think>### journalctl 命令详解 `journalctl` 是 Linux 系统中用于查询和管理 `systemd` 日志的核心工具。它直接访问由 `systemd-journald` 服务收集的系统日志(包括内核、服务和应用日志),无需依赖传统的 `syslog`。以下是常用操作指南: --- #### **1. 基础查询** | 命令 | 功能 | 示例 | |------|------|------| | `journalctl` | 查看完整系统日志(默认按时间倒序) | `journalctl` | | `journalctl -k` | 仅查看内核日志 | `journalctl -k` | | `journalctl -b` | 查看本次启动的日志 | `journalctl -b` | | `journalctl -f` | 实时追踪最新日志(类似 `tail -f`) | `journalctl -f` | --- #### **2. 按条件过滤** | 命令 | 说明 | 示例 | |------|------|------| | `journalctl -u <服务名>` | 查看指定服务的日志 | `journalctl -u nginx.service` | | `journalctl --since <时间>` | 按时间范围查询 | `journalctl --since "2024-05-20 09:00:00"` | | `journalctl -p <级别>` | 按日志级别筛选(如 `emerg`, `alert`, `err`) | `journalctl -p err` | | `journalctl _PID=<进程ID>` | 按进程 ID 过滤 | `journalctl _PID=1234` | --- #### **3. 日志持久化设置** 默认日志存储在内存(`/run/log/journal/`),重启后丢失。启用持久化存储: ```bash sudo mkdir -p /var/log/journal sudo systemd-tmpfiles --create --prefix /var/log/journal sudo systemctl restart systemd-journald ``` 启用后日志将保存至 `/var/log/journal/`[^2]。 --- #### **4. 日志维护** | 操作 | 命令 | 说明 | |------|------|------| | 清理旧日志 | `sudo journalctl --vacuum-time=2weeks` | 删除超过 2 周的日志 | | 查看磁盘占用 | `journalctl --disk-usage` | 显示日志占用空间 | | 限制日志大小 | 编辑 `/etc/systemd/journald.conf` | 设置 `SystemMaxUse=500M` 限制磁盘用量[^3] | --- #### **5. 输出格式控制** | 命令 | 效果 | |------|------| | `journalctl -o json-pretty` | JSON 格式化输出 | | `journalctl -n 20` | 仅显示最后 20 条日志 | | `journalctl --no-pager` | 禁用分页(适合脚本调用) | > ⚠️ **注意**:部分发行版(如 Ubuntu Server)需安装 `systemd-journal-remote` 才能使用完整功能。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值