Java中的Timer类和线程问题

最近用Java开发了一个应用,主要是使用java中的Timer类做定时操作网页的事情。程序的设计是每个用户可能会有至少8个Timer类,这样当用户数多时Timer的数量就呈直线上升了。按照java的官方文档说明,Timer类会自动启动一个新线程,而多个Timer类则会有开辟多个线程,同时Timer类的线程是非daemon(守护)线程,所以一旦启动除非明确cancel掉,是一直存在的。因此,我的这个应用当用户数多了之后,大概100个用户,初步估算有近800个线程,在768M内存的服务器上运行一段时间后内存就飙升至96%多,最后系统响应非常慢,导致宕机。

Java 8 中 HashMap 的性能提升

Java 8 的 Nashorn 引擎

Java 8简明教程

刚开始不太清楚是怎么回事,后来做了个实验,在2G内存的VPS上快速new一万个Timer来,结果5000多个左右的时就报内存溢出,top查看内存为0,同时显示错误,无法创建native thread的错误。后来仔细想想,每个线程也有自己的堆栈,需要消耗内存的,因此当Timer类多的时候内存占用就会直线上升也就不足为奇了。因此在程序中使用线程也是要当心的,虽然线程是个好东西。更多的情况下要考虑线程的复用,比如使用java的线程池时情况就会有天壤之别,同样在这个VPS,我用一个Timer类,快速提交10000个TimerTask,结果内存占用非常小,几乎没有太大的变化,虽然这里只用到了一个线程,可见线程的作用和厉害。

找到了原因,那就是调校优化程序了,要不一个应用几百个用户都撑不住那就掉大了,呵呵。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/c38f14aa1ede561133dbddbd3bb6edda.html