日志切割的方法

2023-05-16

一、关于日志切割

日志文件包含了关于系统中发生的事件的有用信息,在排障过程中或者系统性能分析时经常被用到。对于忙碌的服务器,日志文件大小会增长极快,服务器会很快消耗磁盘空间,这成了个问题。除此之外,处理一个单个的庞大日志文件也常常是件十分棘手的事。

logrotate是个十分有用的工具,它可以自动对日志进行截断(或轮循)、压缩以及删除旧的日志文件。例如,可以设置logrotate,让/var/log/foo日志文件每30天轮循,并删除超过6个月的日志。配置完后,logrotate的运作完全自动化,不必进行任何进一步的人为干预。

二、安装logrotate

系统版本说明

[root@oldboy6 ~]# cat /etc/redhat-release 
CentOS release 6.9 (Final)
[root@oldboy6 ~]# uname -r 
2.6.32-696.el6.x86_64

默认centos系统安装自带logrotate,安装方法如下

yum -y install logrotate crontabs 

软件包信息说明

[root@oldboy6 ~]# rpm -ql  logrotate
/etc/cron.daily/logrotate/etc/logrotate.conf  # 主配置文件
/etc/logrotate.d   # 配置目录

logrotate的配置文件是/etc/logrotate.conf,通常不需要对它进行修改。日志文件的轮循设置在独立的配置文件中,它(们)放在/etc/logrotate.d/目录下。

三、实践配置logrotate

3.1 测试logrotate如何管理日志

这里我们将创建一个10MB的日志文件/var/log/log-file。我们将展示怎样使用logrotate来管理该日志文件。

我们从创建一个日志文件开始吧,然后在其中填入一个10MB的随机比特流数据文件。

[root@oldboy6 ~]# touch /var/log/log-file
[root@oldboy6 ~]# head -c 10M < /dev/urandom > /var/log/log-file 

由于现在日志文件已经准备好,我们将配置logrotate来轮循该日志文件。让我们为该文件创建一个配置文件。

[root@oldboy6 ~]# vim /etc/logrotate.d/log-file 
/var/log/log-file {
    monthly
    rotate 5
    compress
    delaycompress
    missingok
    notifempty
    create 644 root root
    postrotate
        /usr/bin/killall -HUP rsyslogd
    endscript
}

上面的模板是通用的,而配置参数则根据你的需求进行调整,不是所有的参数都是必要的。

3.2 配置文件说明

配置参数说明
monthly日志文件将按月轮循。其它可用值为'daily','weekly'或者'yearly'。
rotate 5一次将存储5个归档日志。对于第六个归档,时间最久的归档将被删除。
compress在轮循任务完成后,已轮循的归档将使用gzip进行压缩。
delaycompress总是与compress选项一起用,delaycompress选项指示logrotate不要将最近的归档压缩,压缩将在下一次轮循周期进行。这在你或任何软件仍然需要读取最新归档时很有用。
missingok在日志轮循期间,任何错误将被忽略,例如“文件无法找到”之类的错误。
notifempty如果日志文件为空,轮循不会进行。
create 644 root root以指定的权限创建全新的日志文件,同时logrotate也会重命名原始日志文件。
postrotate/endscript在所有其它指令完成后,postrotate和endscript里面指定的命令将被执行。在这种情况下,rsyslogd 进程将立即再次读取其配置并继续运行。

3.3 手动运行logrotate

logrotate可以在任何时候从命令行手动调用。要调用为/etc/lograte.d/下配置的所有日志调用logrotate:

[root@oldboy6 ~]# logrotate /etc/logrotate.conf

要为某个特定的配置调用logrotate,执行一次切割任务测试

[root@oldboy6 ~]# ll /var/log/log-file 
-rw-r--r-- 1 root root 10485760 Feb  7 18:50 /var/log/log-file
[root@oldboy6 ~]# logrotate -vf /etc/logrotate.d/log-file 
[root@oldboy6 ~]# ll /var/log/log-file* 
-rw-r--r-- 1 root root        0 Feb  7 19:17 /var/log/log-file-rw-r--r-- 1 root root 10485760 Feb  7 18:50 /var/log/log-file.1

即使轮循条件没有满足,我们也可以通过使用‘-f’选项来强制logrotate轮循日志文件,‘-v’参数提供了详细的输出。

3.4 Logrotate的记录日志

logrotate自身的日志通常存放于/var/lib/logrotate/status目录。如果处于排障目的,我们想要logrotate记录到任何指定的文件,我们可以指定像下面这样从命令行指定。

[root@oldboy6 ~]# logrotate -vf -s /var/log/logrotate-status /etc/logrotate.d/log-file
reading config file /etc/logrotate.d/log-file
reading config info for /var/log/log-file 

Handling 1 logs

rotating pattern: /var/log/log-file  forced from command line (5 rotations)
empty log files are not rotated, old logs are removed
considering log /var/log/log-file
  log does not need rotating
not running postrotate script, since no logs were rotated

3.5 Logrotate定时任务

logrotate需要的cron任务应该在安装时就自动创建了,cron文件的内容:

[root@oldboy6 ~]# cat /etc/cron.daily/logrotate 
#!/bin/sh

/usr/sbin/logrotate /etc/logrotate.conf
EXITVALUE=$?if [ $EXITVALUE != 0 ]; then
    /usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]"
fi
exit 0

四、logrotate生产应用

4.1为nginx设置日志切割

防止访问日志文件过大

[root@oldboy nginx]# cat /etc/logrotate.d/nginx 
/var/log/nginx/*.log {
    daily
    rotate 5
    missingok
    notifempty
    create 644 www www
    postrotate
      if [ -f /application/nginx/logs/nginx.pid ]; then
          kill -USR1 `cat /application/nginx/logs/nginx.pid`
      fi
endscript
}

logrotate工具对于防止因庞大的日志文件而耗尽存储空间是十分有用的。配置完毕后,进程是全自动的,可以长时间在不需要人为干预下运行。

五、其他

5.1 关于USR1信号解释

对于USR1和2都可以用户自定义的,在POSIX兼容的平台上,SIGUSR1和SIGUSR2是发送给一个进程的信号,它表示了用户定义的情况。它们的符号常量在头文件signal.h中定义。在不同的平台上,信号的编号可能发生变化,因此需要使用符号名称。

kill -HUP pid 或者 killall -HUP pName:

其中pid是进程标识,pName是进程的名称。

如果想要更改配置而不需停止并重新启动服务,可以使用上面两个命令。在对配置文件作必要的更改后,发出该命令以动态更新服务配置。根据约定,当你发送一个挂起信号(信号1或HUP)时,大多数服务器进程(所有常用的进程)都会进行复位操作并重新加载它们的配置文件。

5.2 常见配置参数小结

配置参数说明
compress通过gzip压缩转储以后的日志
nocompress不压缩
copytruncate用于还在打开中的日志文件,把当前日志备份并截断
nocopytruncate备份日志文件但是不截断
create mode owner group转储文件,使用指定的文件模式创建新的日志文件
nocreate不建立新的日志文件
delaycompress和 compress 一起使用时,转储的日志文件到下一次转储时才压缩
nodelaycompress覆盖 delaycompress 选项,转储同时压缩。
errors address专储时的错误信息发送到指定的Email 地址
ifempty即使是空文件也转储,这个是 logrotate 的缺省选项。
notifempty如果是空文件的话,不转储
mail address把转储的日志文件发送到指定的E-mail 地址
nomail转储时不发送日志文件
olddir directory转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统
noolddir转储后的日志文件和当前日志文件放在同一个目录下
prerotate/endscript在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
daily指定转储周期为每天
weekly指定转储周期为每周
monthly指定转储周期为每月
rotate count指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份
tabooext [+] list让logrotate不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和 ~
size size当日志文件到达指定的大小时才转储,bytes(缺省)及KB(sizek)或MB(sizem)
missingok在日志轮循期间,任何错误将被忽略,例如“文件无法找到”之类的错误。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

日志切割的方法 的相关文章

  • 如何理解深度学习中的端到端(End-to-end)概念

    在最近的论文阅读中 xff0c 又一次见到作者提到 端到端 xff08 End to end 这个概念 xff0c 但是在专业课的学习和以往查的资料中 xff0c 这个名词并没有被特意地强调过 端到端 xff0c 是相对于 非端到端 而言的
  • 亮屏流程 - 安卓R

    PhoneWindowManager响应电源键 首先按下power键后调用frameworks base services core java com android server policy PhoneWindowManager jav
  • Ubuntu:系统分区

    在系统分区之前 先进行磁盘分区 这里针对的是window10系统下安装ubuntu双系统 需要在window10下进行磁盘分区来安装ubuntu系统 一 磁盘分区 win10系统下 右击此电脑 xff0c 点击管理就进入磁盘管理 这时候可以
  • Android Studio 编译通过,无法运行(RUN灰色,类文件图标为红色J)

    Error描述 xff1a Android Studio版本 xff1a 3 4 1 代码编译通过 xff0c 但是Run按钮呈灰色 2 所有类图标都是红色J 3 点击Run左边的 Edit Configutation 后出现如下界面 解决
  • DataFrame中包含列表元素的深度复制以及关于数据复制的一点思考

    文章目录 DataFrame中包含列表元素的深度复制关于深浅复制的一点思考 DataFrame中包含列表元素的深度复制 思想 xff1a 将DataFrame进行序列化 xff0c 使内部数据和索引之间失去关联 xff0c 达到深度复制的目
  • SpringMVC异常页面跳转

    SpringMVC异常处理 1 首先导入SpringMVC包 创建SpringMVC工程 xff08 简单创建 xff09 span class hljs tag lt span class hljs title dependency sp
  • 创建linux_gnome软件快捷方式简单方法

    之前在一些博客中看到的都比较麻烦 笔者是一名初学者 所以推荐用最简单的方法 有问题欢迎指正 原理 我们只需要在linux系统存放桌面图标的目录下 创建一个空白桌面图标文件 并将后文中的代码引入 步骤 1 在usr share applica
  • twm图形模式以及恢复

    虚拟机VMare8安装Redhat企业版5 xff0c 由于虚拟机崩溃gnome环境被破坏 xff0c 进入后进入twm图形模式 TWM 是TabWindow Manager for the X WindowSystem的简称 xff0c
  • 若依 从下载到成功运行及打包

    官网 xff1a http www ruoyi vip 目录 一 下载并运行项目 二 关于 若依 接口地址配置 2 1 若依的跨域代理介绍 2 2 配置跨域代理 xff0c 调用后台接口 2 2 1 配置 后台 ip 地址 2 2 2 页面
  • ESLint 的使用和.eslintrc.js配置

    使用 ESLint ESLint 详尽使用参见 官方文档 http eslint org docs user guide configuring 配置 ESLint 可以通过以下三种方式配置 ESLint 使用 eslintrc 文件 xf
  • python实现文件传输

    发送者 xff1a send file py span class token keyword def span span class token function send file span span class token punct
  • 那一年读过的技术经典书

    转载请注明 xff1a http blog csdn net xinzhangyanxiang article details 10199757 大学刚毕业 xff0c 总结起来读过的书并不算多 xff0c 而且主要集中在大四的时期读的 x
  • 安装Ubuntu 13.04后要做的六件事

    Raring Ringtail Ubuntu 13 04正式发布了 xff0c 作为幕后开发Ubuntu Linux的公司 xff0c Canonical在为全新安装的系统设置一系列默认值方面已经做得很到位 xff0c 但你可能还是想在几个
  • 快速排序结构体golang

    实现功能说明 列出当前目录的所有文件的修改时间 xff0c 和文件名称 定义的结构体 span class token keyword type span info span class token keyword struct span
  • 代码检视九句箴言

    老东家代码检视的箴言 xff0c 还抽查过背诵 xff0c 这么久了 xff0c 我还记得 xff0c 俗话说 xff0c 好记性比不上烂笔头 xff0c 所以就写在这里了 xff0e 看见了If xff0c 就想Else 看见malloc
  • 关于散列、检索的总结

    文章目录 字典线性表线性表存储顺序线性表存储 散列散列函数内消解开地址法和探查序列检索和删除 外消解溢出区方法桶散列 散列表的性质扩大存储区 xff0c 空间换时间负载因子和操作效率可能的技术和实用情况 本文着重讨论静态字典检索相关的散列问
  • 一份用动画演示操作系统的各个过程的资料

    Animationfor OS ProcessDescription and Control Thedynamic state of a process CPUswitching between processes as a result
  • grep 搜索不包含关键字的行

    核心内容 grep v down v 是不显示匹配上的内容 xff0c 显示不包含down的内容 需求引入 做主机扫描的时候 方便查看在线的主机 dotheright span class hljs variable 64 dotherig
  • 打开一个网页,需要用到多少协议?

    系统环境 xff1a OS xff1a Linux ubuntu 2 6 32 46 generic 105 Ubuntu SMP Fri Mar 1 00 08 49 UTC 2013 i686 GNU Linux 抓包软件 xff1a

随机推荐

  • git从远程仓库中拉取指定分支

    若本地分支不存在的情况 git checkout span class hljs attribute b span 本地分支名称 origin span class hljs subst span 远程分支名称 使用该方式会在本地新建分x
  • linux下 find 文件内容

    功能描述 xff1a 从当前目录里面找到 CUDA VERSION相关信息 第一种实现方法 xff1a find 43 exec 43 grep find span class hljs built in span span class h
  • vim删除包含特定字符串的行

    命令如下 xff1a g str d xff1a 表示后面输入的是vim命令参数 g 表示范围是全局 str 是匹配上的字符串 d delete 表示删除
  • centOS7系统盘扩容

    使用centos7 4 1708 iso安装的virtualbox虚拟机 xff0c 设置的硬盘空间是1T xff0c 安装完成之后 xff0c df h 看到 系统文件容量挂载点 dev mapper centos root50G dev
  • git http-backend基于centos7 httpd

    需要用户名密码的访问 网上已经有人分享了 如果想看 需要用户名密码的访问请出门右转 https www cnblogs com badwood316 p 6398616 html 这里的配置是一种不需要用户名密码 同时可以glone的方式
  • 【ZABBIX】zabbix监控软件5.0版本的安装和使用

    文章目录 一 关闭selinux和防火墙二 下载并安装Zabbix三 测试验证四 添加监控主机 xff08 实例 xff1a crond 43 出图 xff09 警告 微信 钉钉 前言 xff1a zabbix服务器需关闭SELinux 开
  • Mariadb(MySql)开启SSL简明教程

    1 生成CA root 64 www genrsa 2048 gt ca key pem root 64 www openssl req new x509 nodes days 365000 key ca key pem out ca ce
  • Katex、Latex语法手册

    莱斯Rice大学的一个语法手册 xff0c 手册链接 网盘地址 xff1a 链接 xff1a https pan baidu com s 1baoNr XBP oGEfbbqcEPA 提取码 xff1a ob47
  • 工单管理系统otrs

    CentOS7 4安装配置ORTS工单系统 环境 IP 系统 服务 数据库 账户 密码 172 20 17 95 Centos7 4 ORTS root root WEB地址 xff1a 172 20 17 95 otrs index pl
  • 画图工具汇集

    技术传播的价值 xff0c 不仅仅体现在通过商业化产品和开源项目来缩短我们构建应用的路径 加速业务的上线速率 xff0c 也体现在优秀工程师的工作效率提升 产品性能优化和用户体验改善等经验方面的分享 xff0c 以提高我们的专业能力 接下来
  • 常见数据库版本

    SQL Server安装包 考虑到好些新手同学不知道怎么下载自己所需的数据库软件安装包 xff0c 特分享一些我收藏的安装包 现分享SQL Server的一些安装包给大家 根据自身需求下载 xff0c 新手朋友建议下载SQL Server
  • 思维导图工具集

    浏览所有国外资源时使用可以实时网页翻译的浏览器 例如Google Chrome QQ浏览器 360浏览器 Firefox浏览器等 xmind 功能 XMind 一个功能齐全的思维导图和头脑风暴工具 旨在产生想法 激发创造力 提高工作和生活的
  • 自动化运维一体化

    运维一体化中的平台一体化 xff0c 指的是运维一体化与平台一体化 xff0c 其中运维一体化是数据中心在运维方面的运营体系 xff0c 它包括三方面 xff1a 人员组织一体化 流程一体化 平台一体化 一 转型 xff1a 和目前大部从运
  • 技术文档写作

    科技文排版技巧 目录 一 段落格式的设定 2 二 设置标题 3 三 利用 导航 选项 xff0c 对论文进行快速定位 xff08 建立在3的基础上 xff09 4 四 插入 分页符 和 分节符 5 五 页码的设置 6 六自动目录生成 xff
  • 资料目录三

    需要更多资料请添加微信 xff1a Stestack 毕设项目 美食美刻网站制作 视频http yun itheima com course 253 html 资料链接 xff1a http pan baidu com s 1dFkYBXv
  • VMware虚拟机ubuntu显示屏幕太小解决办法

    1 安装VMware Tool需要用到虚拟光驱 xff0c 加载一个ISO文件 2 从 media 中复制到 opt下 3 击ubuntu左侧列表里的DVD图标 xff0c 就会出现VMware Tools的安装文件VMwareTools
  • 面向edas开发的规范

    前言 概述 本文档 主要介绍了 服务开发者基于Aliware做项目开发时 xff0c 从项目环境搭建 xff0c 项目开发 xff0c 项目上线及Aliware 服务功能相关的使用 说明 xff0c 操作步骤及代码示例 应用范围 服务开发者
  • 用 Python 进行金融数据可视化

    用 Python 进行金融数据可视化 Python量化的关键是金融数据可视化 xff0c 无论是传统的K线图 xff0c 还是现在的策略分析 xff0c 都需要大量的可视化图表 具体到编程代码 xff0c 就是使用Python绘图模块库绘图
  • Ubuntu双屏的副屏抖动闪烁

    将设置按如下即可 xff1a
  • 日志切割的方法

    一 关于日志切割 日志文件包含了关于系统中发生的事件的有用信息 xff0c 在排障过程中或者系统性能分析时经常被用到 对于忙碌的服务器 xff0c 日志文件大小会增长极快 xff0c 服务器会很快消耗磁盘空间 xff0c 这成了个问题 除此