当前位置: 首页 > news >正文

Debian 11之解决daemon.log与syslog文件占用空间过大问题

目录

  • 一、syslog , daemon.log日志的用途
    • 1. syslog 是系统日志的聚合文件,记录内核、系统服务及关键服务的运行状态和事件,包括但不限于:
    • 2. daemon.log是守护进程专用日志‌,专门记录系统中守护进程(Daemon)的运行细节,包括:
  • 二、减少日志大小的几种方法
    • 1. 配置logrotate自动轮转日志
    • 2. 手动清理日志文件
    • 3. 设置定时任务定期清理
  • 总结

一、syslog , daemon.log日志的用途

1. syslog 是系统日志的聚合文件,记录内核、系统服务及关键服务的运行状态和事件,包括但不限于:

系统启动/关闭流程中的关键节点信息;
硬件设备(如磁盘、USB)的连接与异常;
用户认证事件(如SSH登录失败记录);
系统守护进程(如systemd)的核心操作日志;
其他未指定独立日志文件的应用程序输出。

2. daemon.log是守护进程专用日志‌,专门记录系统中守护进程(Daemon)的运行细节,包括:

守护进程的启动、停止和重启状态;
进程间通信(如通过D-Bus的消息交互);
守护进程运行中的错误或警告(如配置加载失败);
周期性任务的执行反馈(如定时脚本的输出)。

二、减少日志大小的几种方法

对日志没有正确配置管理的话,会导致日志大小疯狂增长,针对/var/log目录下daemon.log和syslog日志文件过大的问题,可通过以下方法综合处理:

1. 配置logrotate自动轮转日志

修改logrotate配置文件‌,编辑 /etc/logrotate.d/rsyslog 或新增自定义配置文件,设置:

/var/log/syslog
/var/log/daemon.log {daily          # 每日轮转maxsize 200M   # 文件超过200M立即触发轮转 rotate 7       # 保留最近7份历史文件compress       # 启用压缩旧日志 delaycompress  # 延迟压缩(保留前一个未压缩文件)missingok      # 文件不存在时不报错notifempty     # 空文件不轮转 postrotatesystemctl restart rsyslog  # 轮转后重启日志服务endscript
}

2. 手动清理日志文件

  • 快速清空当前日志‌
# 使用 truncate 命令清空文件但不删除文件句柄:
sudo truncate -s 0 /var/log/syslog /var/log/daemon.log  # 立即释放磁盘空间
  • 删除历史归档日志‌
sudo find /var/log -name "syslog.*" -mtime +30 -exec rm {} \;  # 删除30天前的日志

3. 设置定时任务定期清理

通过Systemd定时器‌,执行周期清理任务。

创建服务文件 /etc/systemd/system/clean-log.service:

[Unit]
Description=Clean oversized logs[Service]
ExecStart=/bin/sh -c 'find /var/log -type f $ -name "syslog" -o -name "daemon.log" $ -size +1G -exec truncate -s 0 {} \;'

创建定时器文件 /etc/systemd/system/clean-log.timer:

[Unit]
Description=Daily log cleanup[Timer]
OnCalendar=daily
Persistent=true[Install]
WantedBy=timers.target

启用定时器:

systemctl enable --now clean-log.timer 

通过以上定义,可明确二者在日志记录范围和应用场景上的差异。如需进一步限制其大小,可通过调整日志级别或优化轮转策略实现。

总结

本文介绍syslog , daemon.log日志的用途以及所及日志占用空间的方法。

http://www.xdnf.cn/news/667099.html

相关文章:

  • pyspark实践
  • [yolov11改进系列]基于yolov11引入感受野注意力卷积RFAConv的python源码+训练源码
  • 手机收不到WiFi,手动输入WiFi名称进行连接不不行,可能是WiFi频道设置不对
  • Matlab实现LSTM-SVM时间序列预测,作者:机器学习之心
  • 链表:数据结构的灵动舞者
  • Linux系统-基本指令(3)
  • 智能体赋能效率,企业知识库沉淀价值:UMI企业智脑的双轮驱动!
  • 【Quest开发】空间音频的使用
  • [AI]大模型MCP快速入门及智能体执行模式介绍
  • HJ25 数据分类处理【牛客网】
  • 小白成长之路-Linux程序与进程(一)
  • Linux 使用 Docker 安装 Milvus的两种方式
  • 记忆术-汉字部首编码记忆
  • APP广告变现,开发者如何判断对接的广告SDK安全合规?
  • CQF预备知识:一、微积分 -- 1.6.1 不定积分详解
  • ctf.show pwn入门 堆利用-前置基础 pwn142
  • 【刷题】数组拼接(超聚变暑期实习笔试)
  • MATLAB实现音频参数均衡器(PEQ)
  • 鸿蒙OSUniApp 实现的数字键盘与密码输入框组件#三方框架 #Uniapp
  • 用AxumStatusCode细化Rust Web标准格式响应
  • 动态防御新纪元:AI如何重构DDoS攻防成本格局
  • Spring Boot微服务架构(六):伪装的微服务有哪些问题?
  • npm error Cannot find module ‘negotiator‘ 的处理
  • 从Node.js到Go:如何从NestJS丝滑切换并爱上Sponge框架
  • Siege:开源的 HTTP/FTP 压力测试与基准评估工具!全参数详细教程!Kali Linux教程!
  • deepseek开源资料汇总
  • 34. 自动化测试开发之使用oracle连接池实现oracle数据库操作
  • 鸿蒙OSUniApp 开发的商品筛选器与排序功能#三方框架 #Uniapp
  • mediapipe标注视频姿态关键点
  • LVS 负载均衡群集