更好的方法,跨平台(不依赖平台,比如阿里云的后台)的方法是:spring boot 定时任务,直接在程序里写定时清除日志的任务;以后再说;

============================================

新方法是,利用云平台的功能,举例阿里云:

如:rm -f /usr/local/tomcat/apache-tomcat-9.0.31/logs/*

但是 ,若仅仅像上面那样删除日志,会导致tomcat异常,因为logs目录下 以后不再会有任何日志,可能tomcat发现核心日志文件不存在后(catalina.out 、host-manager.log 等等,具体哪些是核心,咱也不知道)出了异常;

解决方法是重启下:reboot;

综合起来就是:

rm -f /usr/local/tomcat/apache-tomcat-9.0.31/logs/* && reboot; && 的意思是只有上条命令执行成功的情况下,才执行 下一条命令;

=========================以下是旧方法====================================

问题描述,很多时候我们都会遇到 tomcat 日志满的问题,尤其是catalina.out 可能过段时间会达到几十个G的大小,这个时候千万不要用vi来打开他,会直接暴死。

然而很遗憾的是针对这个问题,tomcat从5 - tomcat9 都没有解决,即10年都没有解决,看来需要 程序员自己想法解决。若不解决,那么catalina.out会越来越大,最终导致磁盘满,

应用出现不稳定的情况,我之前遇到过3次,黄俊也遇到了 基本上这个问题 必须彻彻底底的解决掉。

解决方法1:

https://blog.csdn.net/shaonaozu/article/details/52325589?utm_medium=distribute.pc_relevant.none-task-blog-baidujs-9

https://blog.csdn.net/u012365843/article/details/100039849?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-19.nonecase&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-19.nonecase

如果Tomcat的catalina.out日志文件不关闭,该文件会记录所有的Tomcat日志信息,时间长了该文件会非常大的,这样会占用很大的磁盘空间的。所以我们一般都是每个项目独自记录想要看到的日志信息,而不是所有的日志信息。

关闭catalina.out打印日志:

1.在Tomcat的bin目录下找到catalina.sh

2.修改catalina.sh中的对应信息

if [ -z "$CATALINA_OUT" ] ; then
  #CATALINA_OUT="$CATALINA_BASE"/logs/catalina.out
  CATALINA_OUT=/dev/null
fi 3.保存catalina.sh文件并重启Tomcat就OK了!

这种方法虽然可以,但是 程序并不会 向catalina.out里输出日志了,导致开发调试的时候  看不到 任何日志 非常不便于调试,废弃这种方法。

解决方案2:既然日志会满,那么能否通过写脚本来定时清除呢,比如每天晚上 12点 清除一次 catalina.out,不需要重启tomcat,因为仅仅是清空了日志,并没有删除文件,tomcat是可以继续写入日志的。

1. 需要安装centos定时器软件,

yum install crontabs

2.检查 这个定时器软件是否开机自动启动了。

可参考:https://www.cnblogs.com/ftl1012/p/crontab.html

systemctl list-unit-files |grep crond   检查是否存在这个服务

systemctl status crond.service   检查 这个服务当前的状态

3. 编写定时清空 catalina.out 的linux脚本。

#!/bin/sh
echo -n "" > /usr/local/tomcat/apache-tomcat-9.0.31/logs/catalina.out
exit

 4.编写定时器,加入定时任务。

crontab -e //编辑当前用户的crontab文件 默认保存在了/var/spool/cron/里 如下【切记这步一定要用vi直接编辑,不可下载到本地编辑再上传的方式】:

0 9 * * * /usr/local/tomcat/apache-tomcat-9.0.31/bin/clear_catalina_out.sh > /dev/null 2>&1   ---  每天上午9点执行,算了,这个还是保存3天的日志吧,方便紧急情况下 查看解决问题。用下面的,每间隔3天的凌晨执行一次。
0 0 */3 * * /usr/local/tomcat/apache-tomcat-9.0.31/bin/clear_catalina_out.sh > /dev/null 2>&1

按 i 键 粘贴内容后,按esc键 退出编辑 然后输入 :wq 保存就可。

其它说明:0 9 * * * 的解释问题 可以百度,举例:https://tool.lu/crontab/ 这个网站 或 https://blog.csdn.net/xinyflove/article/details/83178876 这个说明

5. 虽然定时删除了 catalina.out,但是还是有其他很多日志,占据空间,这个时候,还需要设置一下 tomcat的其它日志保留日期:

修改好后,上传就可。

6.至此就结束了,reboot重启服务器。就可以制作镜像了。

===========================================================================================================

测试,是否会正确执行,让他每分钟执行一次:

*/1 * * * * /usr/local/tomcat/apache-tomcat-9.0.31/bin/clear_catalina_out.sh > /dev/null 2>&1

切记这步一定要用vi,不可先下载到本地再编辑的方式;

crontab -e  来进行编辑

 然后重启,开始测试,看下 catalina.out 是否会 每分钟 被清空一次。看到通过下面【gif】看到,是正确执行了!!!!!

定时器也是有运行日志的,他的运行日志在这里,我们可以看下:

=============================================================================================================

其它辅助,与本篇无关,当不知所措的时候 可以观察:

JDK + Tomcat 安装 + 制作自定义镜像【第 2.1 篇 Tomcat 日志满问题】的更多相关文章

  1. JDK + Tomcat 安装 + 制作自定义镜像【第 2 篇 Tomcat】

    [第 1 篇 JDK]:https://www.cnblogs.com/del88/p/11842387.html[第 2 篇 Tomcat]:https://www.cnblogs.com/del8 ...

  2. JDK + Tomcat 安装 + 制作自定义镜像【第 1 篇 JDK】

    [第 1 篇 JDK]:https://www.cnblogs.com/del88/p/11842387.html[第 2 篇 Tomcat]:https://www.cnblogs.com/del8 ...

  3. JDK + Tomcat 安装 + 制作自定义镜像【第 3 篇 系统镜像】

    [第 1 篇 JDK]:https://www.cnblogs.com/del88/p/11842387.html[第 2 篇 Tomcat]:https://www.cnblogs.com/del8 ...

  4. Dockerfile制作自定义镜像

    本文介绍最精简的Dockerfile文件构建镜像,Docker启动的时候可以启动一个shell脚本 1.首先编写Dockerfile文件 说明 1.启动的这个shell脚本一定是不退出的,比如服务器的 ...

  5. JDK和Tomcat安装

    JDK安装: 1,选择安装位置,其余默认安装,安装两次,一个是JDK,一个是JRE,安装在两个文件夹中. 2,配置环境变量: 1,新建一个变量,变量名:JAVA_HOME,变量值:C:\Program ...

  6. 05006_Linux的jdk、mysql、tomcat安装

    1.软件包下载链接:软件包下载 密码:advk 2.安装JDK (1)查看当前Linux系统是否已经安装java,输入 rpm -qa | grep java : (2)卸载两个openJDK (3) ...

  7. 五十四.自定义镜像及仓库、持久化存储 、 Docker网络架构

    1. 制作自定义镜像(base基础镜像,搭建共性环境) 基于centos镜像使用commit创建新的镜像文件 基于centos镜像使用Dockerfile文件创建一个新的镜像文件   1.1 使用镜像 ...

  8. Docker 11 自定义镜像

    参考源 https://www.bilibili.com/video/BV1og4y1q7M4?spm_id_from=333.999.0.0 https://www.bilibili.com/vid ...

  9. Tomcat学习笔记【2】--- Tomcat安装、环境变量配置、启动和关闭

    本文主要讲Tomcat的安装和配置. 一 Tomcat安装 1.1 下载 下载地址:http://tomcat.apache.org/ 1.2 安装 Tomcat是不需要安装的,解压压缩包即可. 在安 ...

  10. DokcerFile的添加及如何生成一个自定义镜像mycentos(四)

    最近在学习Docker,用commit去生成一个镜像,但是生成后的镜像非常臃肿,所以去学习了一下DockerFile. 前提条件: 已在虚拟机中成功安装Docker 简单的理解可以如下图所示: Doc ...

随机推荐

  1. Vue3.0 + Element Plus整合实战

    mall-vue3-manage 基于vue3.0 + Element Plus. 整合最新的 Echarts5 强劲的渲染引擎.富文本编辑器 Wangeditor 的后端管理项目. 版本 vue 3 ...

  2. hdu 5234

    题意:求在不超过k的情况下,最多可以得到多少价值. 三维dp,结合01背包,第三维就是用来保存在不同的背包容量下能得到的最大价值,也就是第三维有很多状态. #include<iostream&g ...

  3. Cortex-M3内核介绍

    目录 Cortex Vendor - ARM介绍 ARM主要提供指令集,需要授权 ARM使用的RSIC结构,功耗比较低 Cortex M3整体架构 核心是Processor Core - 包含寄存器和 ...

  4. 永久激活Windows10专业版及其它版本【亲测有效2022-03-16,两种方式】

    前言 小编最近使用公司的电脑,开始出现让你激活的提示,而且每次开机都会弹出来,小编忍住了:但是过不了半个月开始给你在桌面上显示了,一直显示和水印一样.小编忍无可忍,必须找个办法给你消灭掉!!,于是小编 ...

  5. vscode - Prettier插件 统一代码风格规范,保存自动格式化代码

    安装 Prettier - Code formatter prettier安装完毕,使用shift+alt+f就可格式化代码. 如果需要自动保存,要在系统设置中增加"editor.forma ...

  6. [转帖]Docker最佳实践:5个方法精简镜像

    https://juejin.cn/post/6844903880526921741   精简Docker镜像的好处很多,不仅可以节省存储空间和带宽,还能减少安全隐患.优化镜像大小的手段多种多样,因服 ...

  7. 常见的docker hub mirror镜像仓库

    阿里云(杭州) https://registry.cn-hangzhou.aliyuncs.com 阿里云(上海) https://registry.cn-shanghai.aliyuncs.com ...

  8. [转帖]在yum安装本地rpm文件时遇到public key不正确问题

    yum错误:public.gpg.key: import read failed(2). 在yum安装本地rpm文件时遇到public key不正确问题 Downloading Packages:   ...

  9. [转帖]Postmark - 存储性能测试工具

    1. 引言 Postmark是由著名的NAS提供商NetApp开发,用来测试其产品的后端存储性能. Postmark主要用于测试文件系统在邮件系统或电子商务系统中性能,这类应用的特点是:需要频繁.大量 ...

  10. [转帖]Linux系统awk命令详解

    AWK 是一种处理文本文件的语言,是一个强大的文本分析工具. 之所以叫 AWK 是因为其取了三位创始人 Alfred Aho,Peter Weinberger, 和 Brian Kernighan 的 ...