文件过大占服务器内存太大的时候系统会变的很慢,而后打不开,适当的删除些tomcat下的log系统就正常了。内存够了。因此能够适当的删除catalina.out的文件,这个文件在每次重启tomcat的时候会进行更新备份当天的数据,好比在2011-12-15日重启服务了,服务器上有个catalina12-15.log的文件,若是你觉得这就是从上一次重启服务到此次重启服务间得日志文件保存,那我告诉你也我不清楚,可是如今我清楚了,若是你每次都不清除catalina.out的文件,那每次尽管产生了log的文件,后续的东西也仍是会在out的文件上继续追加的写日志,而后你会发现你重启了N次了,删掉了N个log,可是内存仍是没大多少,这个时候果断的在停掉服务后删掉out文件再重启服务应该就OK了。我用的是最 差劲的那个办法了。适当的时候就删掉一些。html
Linux下的tomcat产生的日志文件不象windows下的按时间时间和大小来处理,java
尽管也生成了日志文件catalina.2009-0x-0x.log类型的文件,可是其中的catalina.out文件依然增大;它为啥在增大,为啥在增大,缘由我就不探究了。linux
Tomcat的官方文档,因为是外文,偶尚未看明白di;apache
http://tomcat.apache.org/tomcat-6.0-doc/logging.htmlwindows
听说是修改某些配置能够实现,但愿高人指点,给个官方的解决方案;tomcat
总是增大也不是办法,仍是想其余办法搞定它为好:bash
方法1—分割流服务器
使用cronolog工具切分Tomcat的catalina.out日志文件网络
cronolog一个对日志切分的小工具,其主页在http://cronolog.org/,咱们也能够用它来切分Apache的日志。工具
具体的方法,您能够去google之,这个方法占网络搜索结果的主流;
方法2—脚本流
事情终究不过是个大文件处理的问题,强大的bash来搞定;
使用cron天天来备份当前的catalina.out,而后清空他的内容;
参考脚本以下:
#!/bin/sh
y=`date "+%Y"`
m=`date "+%m"`
d=`date "+%d"`
cd /PATH /tomcat/logs
cp catalina.out catalina.out.$y$m$d
echo > catalina.out
exit
注意linux系统的cron服务是否启动,是否正常工做,还有脚本的存放路径(缘由暂保密)
方法3—猥琐流
打开bin目录下的catalina.sh文件,终究不过是个bash文件,
查找一下,catalina.out总共出现三次;
部分截图:
shift
touch "$CATALINA_BASE"/logs/catalina.out
if [ "$1" = "-security" ] ; then
echo "Using Security Manager"
shift
"$_RUNJAVA" $JAVA_OPTS "$LOGGING_CONFIG" $CATALINA_OPTS \
-Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
-Djava.security.manager \
-Djava.security.policy=="$CATALINA_BASE"/conf/catalina.policy \
-Dcatalina.base="$CATALINA_BASE" \
-Dcatalina.home="$CATALINA_HOME" \
-Djava.io.tmpdir="$CATALINA_TMPDIR" \
org.apache.catalina.startup.Bootstrap "$@" start \
>> "$CATALINA_BASE"/logs/catalina.out 2>&1 &
if [ ! -z "$CATALINA_PID" ]; then
echo $! > $CATALINA_PID
fi
else
"$_RUNJAVA" $JAVA_OPTS "$LOGGING_CONFIG" $CATALINA_OPTS \
-Djava.endorsed.dirs="$JAVA_ENDORSED_DIRS" -classpath "$CLASSPATH" \
-Dcatalina.base="$CATALINA_BASE" \
-Dcatalina.home="$CATALINA_HOME" \
-Djava.io.tmpdir="$CATALINA_TMPDIR" \
org.apache.catalina.startup.Bootstrap "$@" start \
>> "$CATALINA_BASE"/logs/catalina.out 2>&1 &
我的以为也就是这里是写catalina.out文件的;让他写到一个其余的空设备如何?
修改前注意原文件的catalina.sh的备份哟~!!
修改以上代码中的
>> "$CATALINA_BASE"/logs/catalina.out 2>&1 &
为
>> /dev/null 2>&1 &
保存,而后启动tomcat,目前这个 catalina.out一直是空的了。
这个方法是偶本身想到的,我的认为比较勇敢,目前尚未在生产环境测试过。虚拟机测试是经过的。
方法4—人流
这个方法其实就是linux系统管理员手工去删除,人工操做,简称“人流”;
删除以前最好中止tomcat的服务;