遇到错误
java.lang.OutOfMemoryError: unable to create new native thread
at java.lang.Thread.start0(Native Method)at java.lang.Thread.start(Thread.java:597)
at java.util.Timer.<init>(Timer.java:154)
at java.util.Timer.<init>(Timer.java:122)
问题出在线程上,由于内存有限,无法再创建新的线程。
经过查找,得知可以修改java选项减少创建线程的消耗。
JAVA_OPTS=-Xms512M -Xmx1024M -Xss128K
事实上问题仍未得到解决,-Xms512M -Xmx1024M并不是越大越好。
在程序中输出Thread信息,发现Timer的线程很多,也能观察到Timer线程会自动关闭。
当java进程消耗至280M时,tomcat就崩溃了。
仔细检查了一下程序中关于Timer的代码,
修改前是
Timer timer = new Timer(new MyTimerTask(),0,60000);
修改后
Timer timer = new Timer(new MyTimerTask(),10000);
并在MyTimerTask.Run中增加
finally{
Timer timer = new Timer(new MyTimerTask(),60000);
System.gc();//这一条很重要,否则还是会存在大量的timer线程
}
如上修改的原因是当一个task执行完后,再去执行新的task,而不是原来的周期性执行。