首页 > 系统相关 >linux下springboot项目nohup日志或tomcat日志切割处理方案

linux下springboot项目nohup日志或tomcat日志切割处理方案

时间:2024-04-22 15:38:02浏览次数:29  
标签:文件 springboot tomcat 转储 etc logrotate 日志

https://juejin.cn/post/7081890486453010469

通常情况下,我们的springboot项目部署到linux服务器中,通过nohup java -jar xxx.jar &指令来进行后台运行我们的springboot项目。这种方式针对中小型项目来说,还是比较简单方便的。

  • 通过nohup运行springboot项目,默认日志输出到当前目录下的nohup.out文件中。
  • 当将springboot项目打包为war包并放入tomcat中运行,则默认日志输出到tomcat/log/catalina.out文件中。

注意:这两种方式默认的日志文件会越积越多,并且输出的是控制台日志,而不仅仅是在springboot项目中日志框架(如log4j2,logback等)配置及打印的日志,通常情况下,这样的日志记录更全面,包括异常堆栈信息,对于故障排查处理来说还是比较有效的。 然而,这样的日志输出也存在一个问题,不会自动切割备份,日志文件会随着应用程序的运行不断增大,积累到一定量时就导致排查故障、日志查询带来极大的阻碍。 如何解决这个难题呢?

  • 有人说,搭建elk来收集程序运行日志。
  • 也有人说,通过tomcat日志配置来控制日志输出,不输出到catalina.out文件中。(对tomcat运行springboot项目的方式有效) 当然,解决方案有很多种,然而我认为最简单的方式,就是通过logrotate工具来进行日志自动切割,而且像CentOS7等服务器端操作系统中都已经默认自带了该工具。像nginx、mysql等在安装时,实际上也是通过创建logrotate配置文件来进行日志切割的。

小提示:nohup.out、catalina.out日志输出时,均包含了控制台日志,建议在日志框架配置时,将日志配置输出到Console即可,而不需要配置输出到日志文件中,这样可以统一输出到nohup.out文件中进行切割。

如在log4j2配置文件中,最后的输出配置可以参考如下配置:

<root level="info">
    <appender-ref ref="Console"/>
</root>

目前一般linux发行版都自动安装了logrotate工具,一般不需要自行安装。如果没有自带,可以使用yum等命令进行安装。

1. 配置流程

在/etc/logrotate.d/目录下创建一个文件,如tomcat_catalina,写入以下内容:

创建文件并写入内容:

创建文件:

vim /etc/logrotate.d/tomcat_logrotate                  

写入内容:

/home/app/tomcat/logs/catalina.out {
daily
rotate 180
missingok
dateext
#compress
notifempty
copytruncate
#endscript
#size 200M
}

2. 配置说明

  /home/app/tomcat/logs/catalina.out         #服务器中catalina.out存放地址
    daily   #每天切割
    rotate 180  #保留最多180个文件
    missingok  #文件丢失了,继续切割而不报错
    dateext  # 这个参数很重要!就是切割后的日志文件以当前日期YYYYMMDD为格式结尾,如xxx.log-20131216这样,如果注释掉,切割出来是按数字递增,即xxx.log-1这种格式
    #compress  #压缩分割后的文件
    notifempty # 当日志文件为空时,不进行轮转,与 ifempty 相反
    copytruncate   #拷贝原日志文件,并将其大小变为0
    #size 200M  #当catalina.out文件大于200M时,就切割

其他配置选项:

    daily :指定转储周期为每天
    weekly :指定转储周期为每周
    monthly :指定转储周期为每月
    rotate count :指定日志文件删除之前转储的次数,0 指没有备份,5 指保留 5 个备份
    tabooext [+] list:让 logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和~
    missingok:在日志轮循期间,任何错误将被忽略,例如 “文件无法找到” 之类的错误。
    size size:当日志文件到达指定的大小时才转储,bytes (缺省) 及 KB (sizek) 或 MB (sizem)
    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 : 转储时不发送日志文件
    prerotate/endscript: 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行

3. 手动执行

使用以下命令,可以手动执行切割任务。

logrotate -f /etc/logrotate.d/tomcat_logrotate

可选参数:

-d 以预演方式运行 logrotate,不用实际轮训任何日志文件,模拟演练日志轮询并显示输出 -v 显示打印详细信息,相当于debug模式

4. 自定义执行时间

logrotate默认的执行时间不是凌晨0点,Logrotate是基于CRON来运行的,其脚本是/etc/cron.daily/logrotate,实际运行时,Logrotate会调用配置文件/etc/logrotate.conf。这个时间是由CRON控制的,具体可以查询CRON的配置文件/etc/anacrontab(老版本的文件是/etc/crontab),一般默认是3:2:2+(4,45)这个时间段执行。

/etc/anacrontab文件内容:

# /etc/anacrontab: configuration file for anacron

# See anacron(8) and anacrontab(5) for details.

SHELL=/bin/sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# the maximal random delay added to the base delay of the jobs
RANDOM_DELAY=45
# the jobs will be started during the following hours only
START_HOURS_RANGE=3-22

#period in days   delay in minutes   job-identifier   command
1       5       cron.daily              nice run-parts /etc/cron.daily
7       25      cron.weekly             nice run-parts /etc/cron.weekly
@monthly 45     cron.monthly            nice run-parts /etc/cron.monthly
~           

如果想要自己指定时间执行,可简单借助crontab自定义执行即可。

(1)tomcat_logrotate文件从/etc/logrotate.d/中移出来,放到其他目录,如:/home/logrotate/下

(2)crontab添加定时任务执行:crontab -e。如每天23:59分进行切割

59  23 * * *  /usr/sbin/logrotate  /home/logrotate/tomcat_logrotate

标签:文件,springboot,tomcat,转储,etc,logrotate,日志
From: https://www.cnblogs.com/hanby/p/18150703

相关文章

  • day18_我的Java学习笔记 (Logback日志框架、阶段项目--详见视频教程)
    1.日志框架1.1日志技术的概述1.2日志技术体系结构1.3Logback概述需要3个文件:1.4Logback快速入门1.4.1在项目下新建lib文件夹,导入Logback的相关jar包,并全选右键添加到项目依赖库中新建工程:logback-app将3个jar包拷贝到lib目录下全选,右键,选择......
  • SpringBoot模块集成mqtt代码实现
    1//引入pom2<!--mqtt-->3<dependency>4<groupId>org.springframework.boot</groupId>5<artifactId>spring-boot-starter-integration</artifactId>6</dependency>......
  • 日志架构演进:从集中式到分布式的Kubernetes日志策略
    当我们没有使用云原生方案部署应用时采用的日志方案往往是ELK技术栈。这套技术方案比较成熟,稳定性也很高,所以几乎成为了当时的标配。可是随着我们使用kubernetes步入云原生的时代后,kubernetes把以往的操作系统上的许多底层都屏蔽,再由他提供了一些标准接口。同时在kuber......
  • springboot 嵌入式的web容器的的选择
    springboot默认内置tomcat可以替换undertow、jetty、nettytomcattomcat默认200最大线程完整实现了JEE容器和serlet规范tomcat6以后支持Jdk1.4的NIO用于完整支持了javaee因此比较笨重和重量级很多高并发会替换成undertowundertow这个是红帽2012开源出来的一个......
  • 【PLM踩坑记】新建SpringBoot项目,无法使用Java8
    概述今天开始学SpringBoot,需要使用IDEA新建SpringBoot项目。公司使用的Java版本为jdk1.8,这里我选择了这个版本的jdk之后,下面的Java选项不提供Java8。解决方法如下:首先将jdk版本选择为较新的jdk22,然后下面的Java版本随便选择一个。在正式进入项目之后,修改IDEA中的项目设置。点......
  • web server apache tomcat11-14-CGI
    前言整理这个官方翻译的系列,原因是网上大部分的tomcat版本比较旧,此版本为v11最新的版本。开源项目从零手写实现tomcatminicat别称【嗅虎】心有猛虎,轻嗅蔷薇。系列文章webserverapachetomcat11-01-官方文档入门介绍webserverapachetomcat11-02-setup启动web......
  • springboot接口接收xml
    对xml文件的操作也可以借助hutool的XmlUtil.1.xml格式```xml<root> <deviceStatInfoonlineCount="64"offlineCount="2"errorCount="0"/> <data> <recordid="0"name="5号楼10层流量计"status="预警2/正常1......
  • 【SpringBoot】【一】初识数据源连接池
    1 前言上节我们看了看,SpringBoot启动后都有哪些线程,看到有一部分是关于数据源连接池的,那么这节我们就看看数据源连接池都是如何工作的。我们本节就从这两个问题看起:(1)连接池是如何创建的,也就是什么时候创建的呢?(2)连接是什么时候放进连接池的?是创建完就初始化了一批新的连接,还......
  • web server apache tomcat11-12-SSL/TLS Configuration
    前言整理这个官方翻译的系列,原因是网上大部分的tomcat版本比较旧,此版本为v11最新的版本。开源项目从零手写实现tomcatminicat别称【嗅虎】心有猛虎,轻嗅蔷薇。系列文章webserverapachetomcat11-01-官方文档入门介绍webserverapachetomcat11-02-setup启动web......
  • dist资源包放入springboot运行遇到的问题
    1、在vue、react使用npmrunbuild打包将dist包放入resources下2、通过浏览器访问本地在访问路径会出现404,打开dist包下的index.html发现打包后的指向样式不对,更改指向后,发现还是404把拦截器修改为排除所有路径后,页面不再404,说明资源没有显示。修改资源静态映射指向dis......