• TOMCAT 日志自动删除


    TOMCAT 日志自动删除

    背景

    生产环境中tomcat每天都会产生很多日志,如果不清理磁盘容量会不够,手动清理又太麻烦。因此写个脚本每天定时去删除5天前(根据实际情况而定)的日志文件。

     

    编写脚本

    1.写一个/usr/local/script/cleanTomcatlog.sh脚本

    #!/bin/bash
    export LANG=zh_CN
    #tomcat1日志文件路径
    export WEB_TOMCAT1=/usr/local/tomcat1/logs
    #tomcat2日志文件路径
    export WEB_TOMCAT2=/usr/local/tomcat2/logs
    #tomcat3日志文件路径
    export WEB_TOMCAT3=/usr/local/tomcat3/logs
    echo > ${WEB_TOMCAT1}/catalina.out
    echo > ${WEB_TOMCAT2}/catalina.out
    echo > ${WEB_TOMCAT3}/catalina.out
    find ${WEB_TOMCAT1}/* -mtime +5 -type f -exec rm -f {} ;
    find ${WEB_TOMCAT2}/* -mtime +5 -type f -exec rm -f {} ;
    find ${WEB_TOMCAT3}/* -mtime +5 -type f -exec rm -f {} ;

    2.设置cleanTomcatlog.sh脚本可执行

    chmod a+x cleanTomcatlog.sh

    3.在控制台上输入以下命令

      crontab -e

    4.按i键编辑这个文本文件,输入以下内容,每天凌晨4:30重启tomcat

    按esc键退出编辑,输入wq回车保存

      30 04 * * * /usr/local/script/cleanTomcatlog.sh

    按esc键退出编辑,输入wq回车保存

    5.重启定时任务

    [root@]# service crond stop

    [root@]# service crond start

     

    名称解释

    详解 crontab 和 find 命令

    crontab

    通过crontab可以设定程序的执行时间表,例如让程序在每天的8点,或者每个星期一的10点执行一次。
    crontab -l 列出时间表;
    crontab -e编辑时间表;
    crontab -d删除时间表;

    “-l”没什么可说的,就是一个查看而已;
    “-e”是编辑,和vi没什么差别(其实就是用vi编辑一个特定文件);
    “-d”基本不用,因为它把该用户所有的时间表都删除了,一般都是用“-e”编辑把不要了的时间表逐行删除;

    那到底该如何编辑呢?

    crontab文件的格式是:M H D m d CMD。
    一个6个字段,其中最后一个CMD就是所要执行的程序,如cleanTomcatlog.sh。
    M:分钟(0-59)
    H:小时(0-23)
    D:日期(1-31)
    m:月份(1-12)
    d:一个星期中的某天(0-6,0代表周日)

    这5个时间字段用空格隔开,其值可以是一个数字,也可以用逗号隔开的多个数字(或其他) ,如果不需设置,则默认为“*”。

    例如,每天的04点30分执行cleanTomcatlog.sh,就是==30 04 * * * /usr/local/script/cleanTomcatlog.sh==。

     

    find

    基本格式:find  path expression
    1.按照文件名查找
    (1)find / -name httpd.conf  #在根目录下查找文件httpd.conf,表示在整个硬盘查找
    (2)find /etc -name httpd.conf  #在/etc目录下文件httpd.conf
    (3)find /etc -name '*srm*'  #使用通配符*(0或者任意多个)。表示在/etc目录下查找文件名中含有字符串‘srm’的文件
    (4)find . -name 'srm*'   #表示当前目录下查找文件名开头是字符串‘srm’的文件

    2.按照文件特征查找     

    (1)find / -amin -10   # 查找在系统中最后10分钟访问的文件(access time)
    (2)find / -atime -2   # 查找在系统中最后48小时访问的文件
    (3)find / -empty   # 查找在系统中为空的文件或者文件夹
    (4)find / -group cat   # 查找在系统中属于 group为cat的文件
    (5)find / -mmin -5   # 查找在系统中最后5分钟里修改过的文件(modify time)
    (6)find / -mtime -1   #查找在系统中最后24小时里修改过的文件
    (7)find / -user fred   #查找在系统中属于fred这个用户的文件
    (8)find / -size +10000c  #查找出大于10000000字节的文件(c:字节,w:双字,k:KB,M:MB,G:GB)
    (9)find / -size -1000k   #查找出小于1000KB的文件

    3.可以对查找到的文件在进行操作

    -exec command;
    查找并执行命令
    -fprint file
    打印文件完整文件名
    -fprintf file format
    打印文件格式
    -ok command;
    给用户命令执行操作,根据用户的Y 确认输入执行
    -ls
    打印同种文件格式的文件.

    例如:

    find / -name "*xxx*" -ls

    查找根目录下名称包含xxx的文件并显示信息

    find /usr/local/tomcat1/logs/ -mtime +5 -name "*201?*" -exec rm -rf {} ;

    查找出符合条件的日志文件并删除所有的时间表都删除了,一般都是用“-e”编辑把不要了的时间表逐行删除;

     

  • 相关阅读:
    AOP的相关理论介绍
    代码访问数据库时没有报错一直转圈,MySQL不同驱动版本的连接方式
    Linux(CentOS7)设置固定获取IP地址
    NodeJS的安装与配置
    IDEA启动tomcat访问localhost:8080出现404错误
    Win10笔记本电脑外接显示器,如何在笔记本合上的时候让他继续在显示器上使用
    SpringBoot集成Swagger-Bootstrap-UI(已改名为Knife4j)
    Redis学习之Jedis的操作和使用
    SpringBoot整合Swagger2,搭建Restful API在线文档
    IDEA创建SpringBoot项目时出现:Initialization failed for 'https://start.spring.io' Please check URL, network and proxy settings.
  • 原文地址:https://www.cnblogs.com/huanjoyous/p/10810984.html
Copyright © 2020-2023  润新知