一、Logrotate简介

1、Logrotate实际就是对日志进行切割的小工具,他通过让用户来配置规则的方式,检测和处理日志文件。配合Cron可让处理定时化;
2、Logrotate预制了大量判断条件和处理方式,可大大降低手写脚本的负担和出错的可能;
3、Logrorate检测日志文件属性,比对用户配置好的检测条件,对满足条件的再根据用户配置的要求来处理,整个可以通过Cron来定时调度,这其实是非常经典的Linux解决问题的思路,可以好好静下心来品味下,简单,好用。

二、Logrotate运行机制

系统会定时运行logrotate,一般是每天一次。系统是这么实现按天执行的。crontab会每天定时执行/etc/cron.daily目录下的脚本,而这个目录下有个文件叫logrotate

[root@svn ~]# cat /etc/cron.daily/logrotate
#!/bin/sh /usr/sbin/logrotate -s /var/lib/logrotate/logrotate.status /etc/logrotate.conf
EXITVALUE=$?
if [ $EXITVALUE != ]; then
/usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]"
fi
exit

三、Logrotate组成

以下是logrotate运行的关键点:

/usr/bin/logrotate         #程序所在位置
/etc/cron.daily/logrotate #默认让Cron每天执行logrotate一次
/etc/logrotate.conf #全局配置文件;
/etc/logrotate.d #应用自个的配置文件存放目录,覆盖全局配置;

四、安装配置Logrotate

yum install -y logrotate

配置文件logrotate

[root@svn ~]# ll /usr/local/tomcat/logs/catalina.out
-rw-r----- root root 10月 /usr/local/tomcat/logs/catalina.out
[root@svn ~]# cat /etc/logrotate.d/tomcat.conf
/usr/local/tomcat/logs/catalina.out {
daily
copytruncate
rotate
compress
notifempty
dateext
missingok
}

配置文件参数说明:

daily           #表示每天整理一次
rotate #表示保留20天的备份文件
dateext #文件后缀是日期格式,也就是切割后文件是:xxx.log-.gz
copytruncate #用于还在打开中的日志文件,把当前日志备份并截断
compress #通过gzip压缩转储以后的日志(gzip -d xxx.gz解压)
missingok #如果日志不存在则忽略该警告信息
notifempty #如果是空文件的话,不转储
#size 5M #当catalina.out大于5M就进行切割,可用可不用!

五、对日志进行切割测试

1、调试 (d = debug)参数为配置文件,不指定则执行全局配置文件

[root@svn logs]# logrotate -d /etc/logrotate.d/tomcat.conf
reading config file /etc/logrotate.d/tomcat.conf
Allocating hash table for state file, size B Handling logs rotating pattern: /usr/local/tomcat/logs/catalina.out after days ( rotations)
empty log files are not rotated, old logs are removed
considering log /usr/local/tomcat/logs/catalina.out
error: log /usr/local/tomcat/logs/catalina.out last rotated in the future -- rotation forced
log needs rotating
rotating log /usr/local/tomcat/logs/catalina.out, log->rotateCount is
dateext suffix '-20181009'
glob pattern '-[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]'
destination /usr/local/tomcat/logs/catalina.out-.gz already exists, skipping rotation

2、强制执行(-f = force),可以配合-v(-v =verbose)使用,注意调试信息默认携带-v

[root@svn logs]# logrotate -v -f /etc/logrotate.d/tomcat.conf
reading config file /etc/logrotate.d/tomcat.conf
Allocating hash table for state file, size B Handling logs rotating pattern: /usr/local/tomcat/logs/catalina.out forced from command line ( rotations)
empty log files are not rotated, old logs are removed
considering log /usr/local/tomcat/logs/catalina.out
log needs rotating
rotating log /usr/local/tomcat/logs/catalina.out, log->rotateCount is
dateext suffix '-20181009'
glob pattern '-[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]'
copying /usr/local/tomcat/logs/catalina.out to /usr/local/tomcat/logs/catalina.out-
truncating /usr/local/tomcat/logs/catalina.out
compressing log with: /bin/gzip

效果如下:

[root@svn logs]# ll /usr/local/tomcat/logs/
总用量
-rw-r----- root root 10月 : catalina.--.log
-rw-r----- root root 10月 catalina.--.log
-rw-r----- root root 10月 : catalina.out
-rw-r----- root root 10月 catalina.out-.gz
-rw-r----- root root 10月 : host-manager.--.log
-rw-r----- root root 10月 host-manager.--.log
-rw-r----- root root 10月 : localhost.--.log
-rw-r----- root root 10月 localhost.--.log
-rw-r----- root root 10月 : localhost_access_log.--.txt
-rw-r----- root root 10月 localhost_access_log.--.txt
-rw-r----- root root 10月 : manager.--.log
-rw-r----- root root 10月 manager.--.log

这个工具会自动每天帮我们分隔日志并进行打包,不需要我们在写crontab的脚本,非常的好用!

linux运维、架构之路-tomcat日志切割工具 logrotate的更多相关文章

  1. linux运维架构师职业规划

    1.假如你从来未接触过Linux的话,首先要做的就找一本指导书来学习.现在公认的Linux的入门书籍是“鸟哥的私房菜”,讲的很全面,鸟哥的私房菜一共分为两部,一部是基础篇,一部是服务器篇.“鸟哥的私房 ...

  2. Linux运维工程师入门的10大实用工具

    说到工具,在行外可以说是技能,在行内我们一般称为工具,就是运维必须要掌握的工具. 我就大概列出这几方面,这样入门就基本没问题了. 工具如下: 1.Linux系统基础 这个不用说了,是基础中的基础,连这 ...

  3. 日志切割工具logrotate解决Tomcat catalina.out日志过大的问题

    一.介绍日志切割logrotate 对于Linux系统安全来说,日志文件是极其重要的工具.不知为何,我发现很多运维同学的服务器上都运行着一些诸如每天切分Nginx日志之类的CRON脚本,大家似乎遗忘了 ...

  4. Linux 运维测试及第三应用及测试工具

    一 .第三方应用及测试工具链接地址 https://pan.baidu.com/s/1rLQ5NCZvxcy93YQ4fGFaBQ 1.linux LSI系列raid卡监测工具 1)使用参数详解链接: ...

  5. Nginx日志切割工具——logrotate 使用记录

    1.安装 logrotate是Linux系统自带,无需安装 2.配置 进入[/etc/logrotate.d/nginx]文件修改配置 # 需要备份的日志路劲,一个或多个都可以 /data/logs/ ...

  6. tomcat catalina.out日志切割(logrotate)

    简单说明: 1,因为tomcat日志会一直往catalina.out里面输出,所以回到值catalina.out非常大,占用磁盘空间 2,日志非常大,查看日志就需要很长时间. 3,据说catalina ...

  7. 从苦逼到牛逼,详解Linux运维工程师的打怪升级之路

    做运维也快四年多了,就像游戏打怪升级,升级后知识体系和运维体系也相对变化挺大,学习了很多新的知识点. 运维工程师是从一个呆逼进化为苦逼再成长为牛逼的过程,前提在于你要能忍能干能拼,还要具有敏锐的嗅觉感 ...

  8. Linux运维企业架构实战系列

    Linux运维企业架构项目实战系列 项目实战1-LNMP的搭建.nginx的ssl加密.权限控制的实现 项目实战2-LVS.nginx实现负载均衡系列 2.1 项目实战2.1-实现基于LVS负载均衡集 ...

  9. Linux运维企业架构项目实战系列

    Linux运维企业架构项目实战系列 项目实战1—LNMP的搭建.nginx的ssl加密.权限控制的实现 项目实战2—LVS.nginx实现负载均衡系列2.1 项目实战2.1—实现基于LVS负载均衡集群 ...

随机推荐

  1. CMakeLists.txt中使用循环

    编译一个安卓下的so,此so依赖其他的库,通过循环简化操作 set(UVC_LIBS UVCCamera uvc usb100 jpeg-turbo1500) FOREACH(UVC_LIB ${UV ...

  2. TCP/IP笔记——UDP

    OSI模型中最下面的两层用来解决两个硬件设备在物理上的通信问题(如规定怎么将电平信号转换为数字信号),相对应的TCP/IP模型中,这部分代表将会将机器封装为一个MAC地址来实现通讯.网络层是关于,具体 ...

  3. netcore 使用redis session 分布式共享

    首先准备redis服务器(docker 和redis3.0内置的哨兵进行高可用设置) 网站配置Redis作为存储session的介质(配置文件这些略).然后可以了解一下MachineKey这个东西.( ...

  4. Ubuntu 16.04系统挂载4T硬盘

    问题描述: Ubuntu 16.04系统,系统盘为240G固态硬盘,还有1T机械硬盘,现要再添加一个4T硬盘. 问题分析: 使用GTP对硬盘进行分区并挂载硬盘的方法,一般而言服务器上挂载的硬盘都是比较 ...

  5. Cassandra视图

    一.简介 Cassandra作为一个P2P结构的NOSQL数据库,使用与HBase不同的去中心化架构,在国外使用非常广泛,受欢迎程度甚至在Hbase之上.今天这篇文章介绍Cassandra在视图方面设 ...

  6. servlet3.0文件上传与下载

    描述:文件上传与下载是在JavaEE中常见的功能,实现文件上传与下载的方式有多种,其中文件上传的方式有: (1)commons-fileupload: (2)Servlet 3.0 实现文件上传 (3 ...

  7. 剑指Offer编程题(Java实现)——从尾到头打印链表

    题目描述 输入一个链表,按链表值从尾到头的顺序返回一个ArrayList. 解题思路 思路一:使用头插法 使用头插法可以得到一个逆序的链表.遍历链表,每次将所遍历节点插入到链表的头部. 头结点和第一个 ...

  8. UUID工具类及使用

    1.工具类: package UUIdtest; import java.util.UUID; public class UUIDUtil { public static String getUUID ...

  9. 洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈)

    洛谷P1155 双栈排序题解(图论模型转换+二分图染色+栈) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1311990 原题地址:洛谷P1155 双栈排序 ...

  10. 四、JVM — 类文件结构

    类文件结构 一 概述 二 Class 文件结构总结 2.1 魔数 2.2 Class 文件版本 2.3 常量池 2.4 访问标志 2.5 当前类索引,父类索引与接口索引集合 2.6 字段表集合 2.7 ...