0

0

Linux日志管理教程_syslogjournal日志收集与分析

冷漠man

冷漠man

发布时间:2025-12-29 22:27:09

|

307人浏览过

|

来源于php中文网

原创

Linux日志管理核心是journal(systemd-journald)与syslog(如rsyslog)互补共存:journald负责实时采集、结构化存储和快速检索,syslog负责持久化归档、远程转发及SIEM集成。

linux日志管理教程_syslogjournal日志收集与分析

Linux 日志管理核心在于理清 syslog(传统守护进程日志)与 journal(systemd-journald 的二进制日志)的分工、共存关系和协同使用方式。两者不是替代关系,而是互补:journald 负责实时采集、结构化存储和快速检索;syslog(如 rsyslog 或 syslog-ng)则擅长持久化归档、远程转发和与外部 SIEM 系统集成。

理解 journal 和 syslog 的角色分工

journald 是 systemd 的一部分,默认启用,所有 systemd 服务、内核消息、启动过程日志都会自动写入二进制日志(/run/log/journal/ 或 /var/log/journal/)。它支持字段过滤(_PID、UNIT、PRIORITY)、时间范围查询、反向滚动,但日志默认易失(/run 下重启丢失),长期保存需配置持久化。

syslog 守护进程(如 rsyslog)不直接生成日志,而是从 journald 订阅日志流(通过 imjournal 模块),或接收传统 UDP/TCP syslog 报文。它负责按规则写入文本文件(如 /var/log/messages、/var/log/auth.log),支持磁盘轮转、加密传输、写入数据库等高级功能。

关键点:
• journal 是“源头”和“缓冲”,syslog 是“分发器”和“归档器”
• 启用 journald 持久化后,/var/log/journal/ 才能保留开机前日志
• rsyslog 默认通过 imjournal 读取 journal,而非 /dev/log —— 这意味着 journal 必须运行且权限正确

启用 journal 持久化并查看结构化日志

默认 journal 日志存在内存或 /run/log/journal/(volatile),重启即清空。要长期保留:

Sunshine Office Anywhere(CRM集成版)[OA+CRM]
Sunshine Office Anywhere(CRM集成版)[OA+CRM]

CRM集成版基本功能:    内部邮件,短信息,个人文件柜,日程安排,名片录,网络硬盘,个人网址收藏,个人使用情况统计分析。    新闻管理,公告管理,日程安排查询,工作日志查询,公共网址管理,人事档案管理,组织机构信息查询。     企业文档管理,规章制度,电子刊物。    人力资源管理,档案管理,培训管理,奖惩管理,招聘信息,劳动合同    系统单位信息管理,部门信息管理,用户管理,用户角色设

下载
  • 创建目录:sudo mkdir -p /var/log/journal
  • 触发持久化初始化:sudo systemd-tmpfiles --create --prefix /var/log/journal
  • 重启 journald:sudo systemctl restart systemd-journald

常用 journalctl 命令示例:
• 查看本次启动日志:journalctl -b
• 查看某服务日志(含启动失败):journalctl -u sshd.service -n 50
• 按优先级过滤(3=ERROR):journalctl PRIORITY=3
• 实时跟踪并高亮错误:journalctl -f -p err

配置 rsyslog 接收并落盘 journal 日志

确保 rsyslog 已安装并启用 imjournal 模块(新版默认开启):

  • 检查模块加载:grep "imjournal" /etc/rsyslog.conf(应有 $ModLoad imjournal
  • 确认 rsyslog 用户有读 journal 权限:sudo groupadd -f systemd-journal,然后 sudo usermod -a -G systemd-journal syslog
  • 重启服务:sudo systemctl restart systemd-journald rsyslog

此时 /var/log/messages、/var/log/syslog 等文件内容将与 journal 同步(延迟通常<1秒)。rsyslog 可进一步配置规则,例如把 auth 日志单独写入 /var/log/secure:
if $programname == 'sshd' then /var/log/secure

日志分析实用技巧与避坑提示

• 时间对齐:journal 使用纳秒级时间戳,rsyslog 文本日志为秒级。排查问题时优先用 journalctl --since "2024-05-20 14:30:00" 定位起点,再查对应文本日志
• 防止日志爆炸:journal 默认限制 10% 磁盘空间或 4G 大小,可通过 /etc/systemd/journald.confSystemMaxUse=500M 控制
• 远程集中收集:rsyslog 支持 TLS 转发至 Logstash/Splunk;journal 本身不支持远程,必须经 rsyslog 或 journald-gateway(HTTP 接口)中转
• 容器日志:Docker 默认使用 journald 作为日志驱动,docker logs 实际调用 journalctl;Kubernetes 节点上建议统一由 fluentd 或 vector 采集 journal + rsyslog 输出

相关专题

更多
504 gateway timeout怎么解决
504 gateway timeout怎么解决

504 gateway timeout的解决办法:1、检查服务器负载;2、优化查询和代码;3、增加超时限制;4、检查代理服务器;5、检查网络连接;6、使用负载均衡;7、监控和日志;8、故障排除;9、增加缓存;10、分析请求。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

539

2023.11.27

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

218

2023.12.07

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

709

2023.08.22

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

260

2023.10.25

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

66

2025.10.23

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

987

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

45

2025.10.17

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.2万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号