systemd-journald日志服务:systemd-journald-audit.socket

2024-08-27 05:52

本文主要是介绍systemd-journald日志服务:systemd-journald-audit.socket,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

systemd-journald日志服务:systemd-journald-audit.socket

1 systemd-journald日志服务

CentOS在启动后,会创建两个进程:1号进程systemd,2号进程kthreadd,分别负责管理用户态进程和内核进程。而Ubuntu中,1号进程是init进程,systemd则是作为用户态的服务启动。

systemd-journald是由systemd管理的系统日志服务,可以收集日志并将日志保存在二进制文件中,然后通过journalctl命令查看日志。

systemd-journald的配置文件位于/etc/systemd/journald.conf,其中列出的配置是当前的默认配置,如果需要调整可以根据man journald.conf的说明进行调整。

配置解释如下:

  • Storage=auto:日志保存的地方,可以取以下值:volatile(保存在内存)、persistent(保存在磁盘)、auto(根据/var/log/journal目录是否存在决定是保存在内存还是保存在磁盘)、none(接收到日志后可以转发,然后丢弃,并不存储)
  • Compress=yes:保存日志文件时是否压缩
  • SyncIntervalSec=5m:日志从内存同步到磁盘的时间间隔
  • RateLimitIntervalSec=30s、RateLimitBurst=10000:控制单个服务可以产生的日志速率
  • SystemMaxUse=、SystemKeepFree=、SystemMaxFileSize=、SystemMaxFiles=100:磁盘上的日志文件的控制参数
  • RuntimeMaxUse=、RuntimeKeepFree=、RuntimeMaxFileSzie=、RuntimeMaxFiles=100:内存中的日志文件的控制参数
  • MaxRetentionSec:日志文件保存的最长时间
  • MaxFileSec=1month:日志文件轮转的最长时间
  • ForwardToSyslog=yes:收到日志后转发给syslog,一般就是指rsyslog
  • MaxLevelSyslog=debug:转发给syslog的日志的最大级别
  • LineMax=48K:单行日志的最大长度
  • ReadKMsg=yes:控制是否读取内核产生的日志/dev/kmsg

这些配置都是对日志文件的一些参数配置,防止日志文件占用太多空间,但是,对于用户来说,比较关心两个问题:

  • 既然systemd-journald负责接收日志,那用户自己开发的程序是否也可以发送给systemd-journald?如果可以的话,如何配置或者对接呢?
  • 日志文件具体保存在哪里?如何查看日志文件?

2 systemd-journald和systemd-journald-audit.socket的关系

systemd-journald本身是一个日志接收和处理的模块,那么它的日志从哪里来呢?

systemd-journald的作用是收集系统启动阶段的日志以及服务在启动和运行中的日志,因此,如果服务是用systemd管理的,打印到标准输出的信息就会作为日志被systemd-journal获取到。

也就是说,systemd-journal的功能是接收系统内部的日志以及服务的输出的日志,而业务程序自己的日志通常不需要发送给systemd-journald进行管理,如果希望被系统获取到,在后续用于排错,可以使用syslog(man 3 syslog)将日志输出到系统日志中。

使用systemctl查看systemd-journald服务状态时会发现其中有个TriggeredBy字段:

请添加图片描述

该字段是表明一种依赖关系。

systemd-journald.service中有Unit和Service两个部分的配置,其中,Unit通常是一些元数据描述信息,例如Description、Documentation等,Service则是具体的服务启动的方式以及服务的一些相关配置。

这里重点关注systemd-journald.service的Unit中的Requires、After、Before字段(man systemd.unit):

  • Requires=systemd-journald.socket:Requires描述一种强依赖关系,也就是必须先启动Requires才能启动当前服务
  • After=systemd-journald.socket systemd-journald-dev-log.socket systemd-journald-audit.socket syslog.socket:当前服务必须晚于After启动
  • Before=sysinit.target:当前服务必须早于Before启动

因此,需要先启动systemd-journald-audit.socket才能启动systemd-journald.service。

对于Service则主要关注(man systemd.service):

  • ExecStart=/lib/systemd/systemd-journald:指定如何启动systemd-journald服务的命令
  • Restart=always:自动重启
  • Sockets=ssytemd-journald.socket systemd-journald-dev-log.socket systemd-journald-audit.socket:服务启动时从哪些单元继承套接字文件描述符的名称
  • Type=notify:启动完成后会向systemd发送一条就绪通知

总的来说,根据systemd-journald.service的配置只能看出该服务依赖systemd-journald-audit.socket,那么systemd-journald-audit.socket又是什么呢?

systemd-journald-audit.socket中的Unit和Socket的字段解释:

Unit:

  • Before=sockets.target:当前服务必须比sockets.target早启动,sockets.target作为需要使用socket的服务的依赖起始点
  • ConditionSecurity=audit:检查audit功能是否开启
  • ConditionCapability=CAP_AUDIT_READ:检查是否拥有读取audit的权限

Socket:

  • Service=systemd-journald.service:
  • ListenNetlink=audit 1:创建一个套接字去监听netlink,此处表明要接收audit日志

下面用两句话描述systemd-journald-audit.socket服务的作用:

  • 该服务启动时需要先检查audit服务的可用性以及自身是否有权限读取audit
  • 该服务需要创建socket使用netlink机制去接收audit日志

那么,systemd-journald-audit.socket服务在接收到audit日志后会将日志保存起来。

3 systemd-journald保存日志的方式

前面systemd-journald的配置可以看出,日志在保存时可以保存在内存,也可以保存在磁盘,保存在内存中的日志,当机器重启就没了,但是性能会比较好,保存在磁盘中的日志,重启还在,但是性能会差一些。

  • 如果Storage设置为volatile,日志会保存在内存,此时会将日志保存在/run/systemd/journal目录,该目录通常挂载的是tmpfs,也就是保存到内存中
  • 如果Storage设置为persistent,日志会保存在磁盘中,此时会主动创建/var/log/journal目录,并将日志定期同步到该目录
  • 如果Storage设置为auto,不会主动创建/var/log/journal目录,因此,如果/var/log/journal目录不存在,此时跟volatile模式一样,如果/var/log/journal目录存在,此时跟persistent模式一样

4 journalctl命令的使用

为了提高日志存储的效率,日志保存的格式肯定会采用二进制的方式,因此,无法直接打开日志文件查看,需要使用journalctl命令查看。

journalctl常用的查看日志的命令:

  • journalctl:查看所有日志,如果日志量不多,通常可以查看到从系统启动开始的日志
  • journalctl -u systemd-journald:查看systemd-journald服务的日志
  • journalctl -g "success=\w+":通过正则过滤日志
  • journalctl -f:与tail -f一样
  • journalctl -n 10:与tail -n 10一样
  • journalctl -r:逆序查看日志,可以查看最新的日志

journalctl还有一些管理命令:

  • journalctl --disk-usage:可以查看日志在磁盘上的占用空间
  • journalctl --vacuum-size=10485760:将日志的磁盘空间占用减少到某个值一下,此处的单位为字节,这里就是减少到10MB以下
  • journalctl --vacuum-time=1d:删除1天以前的数据
  • journalctl --verify:对日志进行一致性检查
  • journalctl --sync:将未写入的日志同步到磁盘
  • journalctl --relinquish-var:不将日志写到磁盘,只写到/run
  • journalctl --rotate:手动进行日志的轮转
  • journalctl --flush:将/run中的日志刷到/var

这篇关于systemd-journald日志服务:systemd-journald-audit.socket的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110814

相关文章

windos server2022的配置故障转移服务的图文教程

《windosserver2022的配置故障转移服务的图文教程》本文主要介绍了windosserver2022的配置故障转移服务的图文教程,以确保服务和应用程序的连续性和可用性,文中通过图文介绍的非... 目录准备环境:步骤故障转移群集是 Windows Server 2022 中提供的一种功能,用于在多个

解决systemctl reload nginx重启Nginx服务报错:Job for nginx.service invalid问题

《解决systemctlreloadnginx重启Nginx服务报错:Jobfornginx.serviceinvalid问题》文章描述了通过`systemctlstatusnginx.se... 目录systemctl reload nginx重启Nginx服务报错:Job for nginx.javas

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

SpringBoot如何使用TraceId日志链路追踪

《SpringBoot如何使用TraceId日志链路追踪》文章介绍了如何使用TraceId进行日志链路追踪,通过在日志中添加TraceId关键字,可以将同一次业务调用链上的日志串起来,本文通过实例代码... 目录项目场景:实现步骤1、pom.XML 依赖2、整合logback,打印日志,logback-sp

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

我在移动打工的日志

客户:给我搞一下录音 我:不会。不在服务范围。 客户:是不想吧 我:笑嘻嘻(气笑) 客户:小姑娘明明会,却欺负老人 我:笑嘻嘻 客户:那我交话费 我:手机号 客户:给我搞录音 我:不会。不懂。没搞过。 客户:那我交话费 我:手机号。这是电信的啊!!我这是中国移动!! 客户:我不管,我要充话费,充话费是你们的 我:可是这是移动!!中国移动!! 客户:我这是手机号 我:那又如何,这是移动!你是电信!!

基于SpringBoot的宠物服务系统+uniapp小程序+LW参考示例

系列文章目录 1.基于SSM的洗衣房管理系统+原生微信小程序+LW参考示例 2.基于SpringBoot的宠物摄影网站管理系统+LW参考示例 3.基于SpringBoot+Vue的企业人事管理系统+LW参考示例 4.基于SSM的高校实验室管理系统+LW参考示例 5.基于SpringBoot的二手数码回收系统+原生微信小程序+LW参考示例 6.基于SSM的民宿预订管理系统+LW参考示例 7.基于

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录 在深度学习项目中,目标检测是一项重要的任务。本文将详细介绍如何使用Detectron2进行目标检测模型的复现训练,涵盖训练数据准备、训练命令、训练日志分析、训练指标以及训练输出目录的各个文件及其作用。特别地,我们将演示在训练过程中出现中断后,如何使用 resume 功能继续训练,并将我们复现的模型与Model Zoo中的