Java中使用Timer要注意的一点
2012-11-28 18:56
183 查看
遇到错误
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,而不是原来的周期性执行。
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,而不是原来的周期性执行。
相关文章推荐
- java中使用try-catch-finally一点值得注意的事
- JAVA学习中的一点小发现:LinkedList中.poll()方法在输出时使用应注意的小点
- Java Executor Service 使用要注意的一点
- 关于Java开发中使用Oracle数据库的一点注意事项
- Java使用Equals的一点注意点
- Java开发中使用Oracle数据库的一点注意事项
- 使用Java中的Timer和TimerTask
- 浅析Java执行外部命令的几个要点(1)——简单的使用范例以及在Cygwin上的注意点
- substance在java swing中使用注意事项
- Java中取一个随机数-Random类的使用注意
- 关于java中jar包使用的一点心得(命令行模式下)
- 顺序表java.util.list使用注意点
- Stanford CoreNLP使用需要注意的一点
- nrf51822在使用Timer1和Timer2定时器的时候如何设置定时注意地方
- Java中Timer的使用
- Java中的Timer和TimerTask的使用
- java类集---Map使用注意事项
- Java多线程使用Synchronized需注意锁的永远是对象
- java jpcap使用的注意事项
- java代码中使用cookie中的一个注意点