daemon.log 系统服务日志

daemon.log系统服务日志管理

  • 时间:2021年4月22日
  • 基于debian系统 linux-3.10内核,全志T3平台

程序放到服务中启动发现程序中的打印信息全部被记录到/lib/log/daemon.log文件中,由于不停的运行程序导致硬盘写满。现需要对系统服务程序的log日志进行管理

  • 首先需要对 rsyslog配置进行研究
配置文件:/etc/rsyslog.conf ,  /etc/rsyslog.d/
主程序:/usr/sbin/rsyslogd
模块路径:/usr/lib/systemd/system/rsyslog.service
  • 定位配置文件为</etc/rsyslog.conf>
#  /etc/rsyslog.conf    Configuration file for rsyslog.
# 
#                       For more information see
#                       /usr/share/doc/rsyslog-doc/html/rsyslog_conf.html

#################
#### MODULES ####
#################
module(load="imuxsock") # provides support for local system logging
module(load="imklog")   # provides kernel logging support
#module(load="immark")  # provides --MARK-- message capability
# provides UDP syslog reception
#module(load="imudp")
#input(type="imudp" port="514")
# provides TCP syslog reception
#module(load="imtcp")
#input(type="imtcp" port="514")

###########################
#### GLOBAL DIRECTIVES ####
###########################
#
# Use traditional timestamp format.
# To enable high precision timestamps, comment out the following line.
#
$ActionFileDefaultTemplate RSYSLOG_TraditionalFileFormat
#
# Set the default permissions for all log files.
#
$FileOwner root
$FileGroup adm
$FileCreateMode 0640
$DirCreateMode 0755
$Umask 0022
#
# Where to place spool and state files
#
$WorkDirectory /var/spool/rsyslog

#
# Include all config files in /etc/rsyslog.d/
#
$IncludeConfig /etc/rsyslog.d/*.conf

###############
#### RULES ####
###############
#
# First some standard log files.  Log by facility.
#
auth,authpriv.*                 /var/log/auth.log
*.*;auth,authpriv.none          -/var/log/syslog
#cron.*                         /var/log/cron.log
daemon.*                        -/var/log/daemon.log
kern.*                          -/var/log/kern.log
lpr.*                           -/var/log/lpr.log
mail.*                          -/var/log/mail.log
user.*                          -/var/log/user.log
#
# Logging for the mail system.  Split it up so that
# it is easy to write scripts to parse these files.
#
mail.info                       -/var/log/mail.info
mail.warn                       -/var/log/mail.warn
mail.err                        /var/log/mail.err
#
# Some "catch-all" log files.
#
*.=debug;\
        auth,authpriv.none;\
        news.none;mail.none     -/var/log/debug
*.=info;*.=notice;*.=warn;\
        auth,authpriv.none;\
        cron,daemon.none;\
        mail,news.none          -/var/log/messages
# Emergencies are sent to everybody logged in.
*.emerg                         :omusrmsg:*

找到daemon

daemon.*                        -/var/log/daemon.log
* 意为所有级别的信息全部输出到daemon.log文件中

改为

daemon.=notice                      -/var/log/daemon.log
意为 最具有重要性的普通条件的信息

修改之后普通的打印信息就不会输出到daemon.log文件中了

列举 rsyslog 的日志的类型和级别

Rsyslog的日志类型
auth            pam产生的日志信息
authpriv        ssh,ftp等登录信息的验证信息
cron            计划任务相关信息
kerl            内核信息
lpr             打印打印
mail            邮件信息
daemon          系统服务相关日志
mark(syslog)   Rsyslog服务内部信息,时间标识信息
news            新闻组信息
user            用户程序产生的相关信息
Rsyslog的日志级别:
7 debug        调试信息的日志,日志信息最多
6 info         一般信息的日志,最常用
5 notice       最具有重要性的普通条件的信息
4 warning      警告级别
3 error        错误级别,阻止某个功能或者模块不能正常工作的信息
2 crit         严重级别,阻止整个系统或者整个软件不能正常工作的信息
1 alert        需要立刻修改的信息
0 emerg        内核崩溃等严重信息
none           不记录任何信息
  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用logrotate来进行每天的日志清理。logrotate是一个Linux系统中的工具,用于管理日志文件的轮转和压缩。它可以根据预设的规则定期轮转日志文件,以避免日志文件过大占用过多磁盘空间。 要使用logrotate进行每天的日志清理,你需要创建一个logrotate配置文件。在这个配置文件中,你可以指定要轮转的日志文件、轮转的频率以及其他相关的设置。 以下是一个示例的logrotate配置文件,假设你要清理的日志文件是/var/log/daemon.log: ``` /var/log/daemon.log { daily rotate 7 compress delaycompress missingok notifempty create 0640 root adm sharedscripts postrotate /etc/init.d/rsyslog restart endscript } ``` 在这个示例中,配置文件指定了以下设置: - `daily`:表示每天轮转一次日志文件。 - `rotate 7`:表示保留最近7个轮转后的日志文件,旧的日志文件将被删除。 - `compress`:表示压缩轮转后的日志文件。 - `delaycompress`:表示在下一次轮转时才压缩上一次轮转后的日志文件。 - `missingok`:表示如果日志文件不存在,不报错继续执行。 - `notifempty`:表示如果日志文件为空,不轮转。 - `create 0640 root adm`:表示创建新的日志文件时的权限和所属用户组。 - `sharedscripts`:表示在执行轮转前后执行脚本。 - `postrotate`和`endscript`之间的部分是在轮转后执行的脚本。在这个示例中,它重新启动了rsyslog服务,以确保日志继续写入新的日志文件。 你可以将以上配置保存为一个文件,比如/etc/logrotate.d/daemon,然后logrotate会自动按照配置文件进行日志轮转和清理。 请注意,logrotate的具体参数和行为可以根据你的需求进行调整。你可以查看logrotate的文档或使用`man logrotate`命令来获取更多详细的信息和示例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值