在我的java web应用程序中,我有一个后台工作线程,它需要大量的堆栈空间,因为它使用activiti工作流引擎和groovy脚本任务运行一个非常复杂的工作流。
目前,我需要在 64 位 Java 和 Tomcat 上将 JVM Xss 设置高达 16MB,以规避任何 StackOverflowError。如果发生错误,堆栈跟踪确实很大(几百行长),但这一切都发生在引擎内部,所以我对此无能为力。
现在我的问题是:有没有办法在运行时增加单个线程的堆栈大小?
我想将应用程序中所有线程的 JVM 默认 Xss 设置降低到 512k,我知道这已经足够了,并且只用 16M 运行工作线程。
Java API 为 Thread 类的构造函数提供了有关此主题的一些信息:
public Thread(ThreadGroup group,
Runnable target,
String name,
long stackSize)
但它提到,该行为无法保证([1]),并且我没有找到任何信息,如果它可以在 Windows 上运行。
另外,如果一个线程的堆栈空间无法增加,而我必须指定16MB作为默认值,那么如此高的设置会产生什么后果?这是否意味着每个新线程在初始化时都会保留 16MB 内存(即 200 个线程 * 16MB:3.2 GB)?
据我从 jconsole 和 taskmgr 得知,自从 Xss 设置增加以来,内存占用似乎没有太大变化,但也许我遗漏了一些东西。
任何帮助或澄清将不胜感激。
[1]: http://docs.oracle.com/javase/6/docs/api/java/lang/Thread.html#Thread(java.lang.ThreadGroup http://docs.oracle.com/javase/6/docs/api/java/lang/Thread.html#Thread(java.lang.ThreadGroup、java.lang.Runnable、java.lang.String、长)