一、cronlog
采用cronlolog工具对日志拆分的方式处理该问题
1、下载cronolog工具,我下载的版本是cronolog-1.6.2
(yum安装:yum install cronolog)
2、将下载好的文件解压,tar xvzf cronolog-1.6.2.tar.gz
3、切换到解压后的文件目录下:cd cronolog-1.6.2
4、初始化和编译安装
1 | ./configure --prefix=/usr/local/cronolog |
5、查看安装版本
1 | #cronolog --version |
6、修改tomcat的启动文件(tomcat目录/bin/catalina.sh)
1 | vi catalina.sh |
(1)修改输出日志路径
修改:
1 | if [ -z "$CATALINA_OUT" ] ; then |
为:
1 | if [ -z "$CATALINA_OUT" ] ; then |
(2)删除生成日志文件
注释:
1 | touch "$CATALINA_OUT" |
(3)修改启动脚本参数(两项)
修改:
org.apache.catalina.startup.Bootstrap "$@" start \
>> "$CATALINA_OUT" 2>&1 "&"
为:
org.apache.catalina.startup.Bootstrap "$@" start 2>&1 \
| /usr/local/sbin/cronolog "$CATALINA_OUT" >> /dev/null &
7、重启tomcat
tomcat输出日志文件分割成功,输出log文件格式为:catalina.2015-06-30.out
二、logrotate
利用Linux自带的logrotate程序来解决catalina.out的日志轮转问题
1.首先编辑logrotate.conf文件,打开compress选项(去掉注释)
1 | [root@localhost ~] |
2.添加指定文件,在/etc/logrotate.d/目录下新建一个名为tomcat的文件
1 | [ ] |
参数说明:
copytruncate #备份日志并截断源文件
nocopytruncate # 备份日志文件不截断
dateext #使用当期日期作为命名格式
notifempty #当日志文件为空时,不进行轮转
daily # 每天进行文件的轮转
size 16M # 当文件大于16MB时,就会轮转
rotate 30 #指定日志文件删除之前转储的次数
3.执行方式
①自动执行原理
1 | 1.每天晚上crond守护进程会运行在/etc/cron.daily目录中的任务列表; |
②手动执行:logrotate /etc/logrotate.conf
③只轮转刚刚的tomcat配置文件:logrotate –force /etc/logrotate.d/tomcat
三、log4j
Tomcat7.0.55下使用Log4j 接管 catalina.out 日志文件生成方式,按天存放,解决catalina.out日志文件过大问题
- 准备jar包:
log4j-1.2.17.jar (从 http://www.apache.org/dist/logging/log4j/1.2.17/ 下载)
tomcat-juli.jar, tomcat-juli-adapters.jar (从http://www.apache.org/dist/tomcat/tomcat-7/v7.0.55/bin/extras/下载,根据你的Tomcat版本选择对应的分支) - 将上面的三个jar包拷贝到 Tomcat 的 lib 目录下;
- 将 tomcat-juli.jar 拷贝到 Tomcat 的 bin 目录下,替换原有的jar包;
- 修改 Tomcat 的 conf/context.xml 文件,将
为
(增加 swallowOutput=”true” 的属性配置,只有这样才能完全的把tomcat的stdout给接管过来。这一步很关键 在官网及网上找了许多资料都没有提及。); - 删除 Tomcat 的 conf/logging.properties 文件(或者重命名-建议);
- 在 Tomcat 的 lib 目录下创建 log4j.properties 文件,然后重启服务器:
1 | log4j.rootLogger=INFO, CATALINA |
四、shell脚本切割
通过shell脚本的方式切割每天的日志
windows
部署在windows服务器下的tomcat,将tomcat控制台日志记录到日志文件中
https://www.cnblogs.com/linaGh/p/7777915.html
对于抛出的异常错误,不会被存到文件中的,可以修改代码或者修改cmd属性-布局中的高度,默认是300
高度即行数,设置大点就可以看到没有存到文件中的日志信息
作者:Rooot
链接:https://www.jianshu.com/p/396675386a43
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。