日期:2014-05-16 浏览次数:20881 次
Tomcat作为开源的服务器,性能与稳定性上比起一些商业服务器还是要差一些。将项目部署到Tomcat后隔段时间就会死掉,出现这种问题的主要原因可能是内存数据溢出,因为Tomcat容器在发生大量与数据库交互查询或者操作的时候很容易出现问题。定时重启是一个很好的补救措施,定时重启可以定时的清理内存也降低了Tomcat运行的风险,从而保持tomcat的最佳性能。 
(1)写一个shell脚本mytt.sh,重新启动tomcat 
#!/bin/sh 
pid=`ps aux | grep tomcat | grep -v grep | grep -v retomcat | awk '{print $2}'` 
echo $pid 
if [ -n "$pid" ] 
then 
{ 
?? echo ===========shutdown================ 
?? /usr/local/tomcat6/bin/shutdown.sh 
?? sleep 2 
?? pid=`ps aux | grep tomcat | grep -v grep | grep -v retomcat | awk '{print $2}'` 
?? if [ -n "$pid" ] 
?? then 
??? { 
????? sleep 2 
????? echo ========kill tomcat begin============== 
????? echo $pid 
????? kill -9 $pid 
????? echo ========kill tomcat end============== 
??? } 
?? fi 
?? sleep 2 
?? echo ===========startup.sh============== 
?? /usr/local/tomcat6/bin/startup.sh 
} 
else 
echo ===========startup.sh============== 
/usr/local/tomcat6/bin/startup.sh 
Fi 
提示:文件名可以随便取,不过注意不要包含“tomcat”的字样,不然会被以上脚本误以为是tomcat的相关进程直接杀掉,从而无法执行后面的启动命令。 
(2)把mytt.sh文件放到root目录下,并修改权限为可执行文件。 
(3)在控制台上输入以下命令 
? crontab –e 
(4)按i键编辑这个文本文件,输入以下内容,每天凌晨5:00重启tomcat 
? 00 05 * * * /root/mytt.sh 
? 
? 按esc键退出编辑,输入wq回车保存 
(5)启动定时服务 
[root@]# service crond stop 
[root@]# service crond start 
(6)乱码问题 
手工重启与默认系统任务自动重启的字符集是不一样的。在jsp中加入<%=System.getProperty( "file.encoding")%>,可以发现系统自动重启与手工自动重启结果不一样,自动重启打印的结果是ANSI_X3.4-1968,手工重启打印的是GB18030. 
作者的项目中使用了volicity生成页面,自动重启后生成的页面就会出现乱码。在tomcat的bin下面找到catalina.sh,在里面加上“CATALINA_OPTS=-Dfile.encoding=GB18030”就可以解决这个问题。